我正在阅读 Koenig 的 Accelerated C++。他写道:“新的想法是我们可以使用 + 来连接一个字符串和一个字符串文字 - 或者,就此而言,两个字符串(但不是两个字符串文字)。
好吧,我想这是有道理的。现在到两个单独的练习来说明这一点。
以下定义是否有效?
const string hello = "Hello";
const string message = hello + ",world" + "!";
现在,我尝试执行上述操作并且成功了!所以我很高兴。
然后我试着做下一个练习;
const string exclam = "!";
const string message = "Hello" + ",world" + exclam;
这不起作用。现在我明白这与你不能连接两个字符串文字的事实有关,但我不明白为什么我设法让第一个例子工作之间的语义差异(不是“,世界”和“! "两个字符串字面量?这不应该不起作用吗?)但不是第二个。
最佳答案
const string message = "Hello" + ",world" + exclam;
+
运算符具有从左到右的结合性,因此等效的括号表达式为:
const string message = (("Hello" + ",world") + exclam);
如您所见,两个字符串文字 "Hello"
和 ",world"
是首先“添加”的,因此是错误的。
被连接的前两个字符串之一必须是 std::string
对象:
const string message = string("Hello") + ",world" + exclam;
或者,您可以强制第二个 +
首先通过括号括起来表达式的该部分:
const string message = "Hello" + (",world" + exclam);
您的第一个示例 (hello + ",world"+ "!"
) 有效,因为 std::string
(hello
) 是最左边 +
的参数之一。 +
被评估,结果是一个带有连接字符串的 std::string
对象,然后连接生成的 std::string
用 "!"
.
至于为什么你不能使用+
连接两个字符串文字,这是因为字符串文字只是一个字符数组(一个const char [N]
其中 N
是字符串的长度加一,用于空终止符)。在大多数情况下使用数组时,它会转换为指向其初始元素的指针。
所以,当您尝试执行 "Hello"+ ",world"
时,您真正想做的是将两个 const char*
加在一起,这是不可能的(将两个指针加在一起意味着什么?)如果是这样,它就不会做你想做的事。
请注意,您可以通过将字符串文字彼此相邻放置来连接它们;比如下面两个是等价的:
"Hello" ",world"
"Hello,world"
如果您想将一个长字符串文字分成多行,这很有用。但是,它们必须是字符串文字:这不适用于 const char*
指针或 const char[N]
数组。
关于c++ - 连接两个字符串文字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6061648/