c – 为什么不能将int(表示ASCII字符)转换为std :: string而没有缠绕在int上的花括号?

前端之家收集整理的这篇文章主要介绍了c – 为什么不能将int(表示ASCII字符)转换为std :: string而没有缠绕在int上的花括号?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
int main() {

    std::string A;
    A += (std::string)65;
    std::cout << A;

}

上面的代码不起作用.它会抛出编译器错误.但下面的代码有效.

int main() {

    std::string A;
    A += (std::string){65};
    std::cout << A;

}

当我用花括号包裹65时,它被解释为像我想要的那样的ASCII A,但没有花括号,程序不起作用.我也尝试在括号中放入多个数字,如下所示:

int main() {

   std::string A;
   A += (std::string){65,66};
   std::cout << A;

}

这将打印出AB.我希望有人可以为我解决这个问题.

解决方法

由于这个构造函数的第二个和第三个工作:
basic_string( std::initializer_list<CharT> init,const Allocator& alloc = Allocator() );

也就是说,每当编译器看到花括号时,它就会将{…}转换为std :: initializer_list< T>为了合适的T.

在您的情况下,它转换为std :: initializer_list< char>然后传递给上面提到的std :: string构造函数.

由于存在=的重载,它需要std :: initializer_list< char>:

basic_string& operator+=( std::initializer_list<CharT> ilist );

你可以这样写:

std::string s;

s += {65};
s += {66,67};

这也应该有效.

请注意,您也可以这样写:

s += 65;

即使这样也行,但由于其他原因 – 它会调用以下重载:

basic_string& operator+=( CharT ch );

在这种情况下,65(即int)转换为char类型.

希望有所帮助.

猜你在找的C&C++相关文章