我制作了一个模板,用于添加给出的数据。如果我像这样使用它,编译器将in_1和in_2声明为const char *,并且代码不会编译。
#include <iostream>
using namespace std;
template <class T>
T addstuff(T part_1, T part_2){
return(part_1+part_2);
}
int main(int argc, char const *argv[])
{
auto in_1="Shut ";
auto in_2="up.";
cout<<addstuff(in_1, in_2)<<endl;
return 0;
}
如果我声明in_1和in_2 std :: string,它就像魅力一样。
为什么不能(或不)编译器自动声明这些字符串std :: string?
答案 0 :(得分:4)
你无法“写”到你的自动变量的原因是它是一个const char *或const char [1],因为这是任何字符串常量的类型。
auto的意思是解析为“最适合”赋值类型的“最简单”类型。编译器“不期待看到你对变量做了什么”,所以它不明白以后你会想要写入这个变量,并用它来存储一个字符串,所以std :: string会更有意义。
您的代码可以以多种不同的方式工作,这是一个有意义的方法:
std::string default_name = "";
auto name = default_name;
cin >> name;
答案 1 :(得分:4)
因为字符串文字的类型为const char[N+1]
,而不是std::string
。
这只是语言的一个事实。
他们本可以这样做,auto
有一个字符串文字的特殊情况,但这将是不一致的,令人惊讶的,并且收益甚微。
答案 2 :(得分:1)
如果您使用字符串文字,auto
将按预期工作。
在C ++ 14,C ++ 17或C ++ 20中,您可以在引号后放置s
,它会创建std::string
而不是const char*
字符串。
这可以与auto
一起使用来创建std::string
:
auto hello = "hello"s;
默认情况下不启用字符串文字。启用字符串文字的一种方法是将以下内容放在源文件的顶部:
#include <string>
using namespace std::string_literals;
例如,此循环适用于std::string
(s
添加到字符串文字中),但不适用于const char*
类型字符串文字:
for (auto &x : hello) {
std::cout << "letter: " << x << std::endl;
}
以下是the ""s operator的cppreference页面。
答案 3 :(得分:0)
auto
会将变量声明为初始化它的表达式的编译时类型。
字符串文字的类型为const char*
,而不是std::string
。