为什么“auto”将字符串声明为const char *而不是std :: string?

时间:2014-01-01 14:05:38

标签: c++ string c++11 auto

我制作了一个模板,用于添加给出的数据。如果我像这样使用它,编译器将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?

4 个答案:

答案 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::strings添加到字符串文字中),但不适用于const char*类型字符串文字:

for (auto &x : hello) {                                                                        
    std::cout << "letter: " << x << std::endl;                                                         
}

以下是the ""s operator的cppreference页面。

答案 3 :(得分:0)

auto会将变量声明为初始化它的表达式的编译时类型。

字符串文字的类型为const char*,而不是std::string