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 – 为什么不能将int(表示ASCII字符)转换为std :: string而没有缠绕在int上的花括号?全部内容,希望文章能够帮你解决c – 为什么不能将int(表示ASCII字符)转换为std :: string而没有缠绕在int上的花括号?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)