如何使用C++引用交换两个 C 样式字符串
How to swap two C style strings using C++ references?
下面的代码给了我一个编译错误,但我不明白我做错了什么。很抱歉问这么愚蠢的问题。
$ cat swapcstrings.cc
#include <iostream>
void swap(char*& c, char*& d) {
char* temp = c;
c = d;
d = temp;
}
int main() {
char c[] = "abcdef";
char d[] = "ghijkl";
std::cout << "[" << c << "," << d << "]n";
swap(c, d);
std::cout << "[" << c << "," << d << "]n";
}
$ g++ swapcstrings.cc
swapcstrings.cc: In function ‘int main()’:
swapcstrings.cc:13: error: invalid initialization of non-const reference of type ‘char*&’ from a temporary of type ‘char*’
swapcstrings.cc:3: error: in passing argument 1 of ‘void swap(char*&, char*&)’
$
数组不能
修改,它们只是衰减到临时指针,它们不是真正的指针,不能交换。数组的地址无法更改,并且当您尝试将从数组获得的临时指针绑定到非const
引用时,编译器会出错,这违反了语言规则。
声明数组,然后交换指向它们的两个指针。
char a[] = "abcdef";
char b[] = "defghi";
char* aptr = a, *bptr = b;
std::cout << "[" << aptr << "," << bptr << "]n";
swap(aptr, bptr);
std::cout << "[" << aptr << "," << bptr << "]n";
或者,如果可以更改函数的原型,请首先使用const char*
:
void swap(const char*& c, const char*& d) {
const char* temp = c;
c = d;
d = temp;
}
const char* c = "abcdef", // These must be const char* because the arrays are
* d = "ghijkl"; // const char[N]
std::cout << "[" << c << "," << d << "]n";
swap(c, d);
std::cout << "[" << c << "," << d << "]n";
c
和d
是数组。它们将自动转换为需要指针的指针。这是编译器输出所讨论的"临时"。可以这样想:
char c[] = "abcdef", d[] = "ghijkl";
char *cp = (char*)c, *dp = (char*)d;
swap(cp, dp);
以上会编译,但只能交换cp
和dp
,而不是原始的c
和d
。由于上面的代码为这些指针提供了名称,因此您现在也可以引用它们。但是在您的原始代码中,临时代码没有名称,对它们的任何修改都表明可能存在错误。所以编译器不会让你这样做,而是会抱怨。
如果要在其数组中交换 C 样式字符串,则必须一次交换一个字符:
template<size_t n> void swap(char (&a)[n], char (&b)[n]) {
for (size_t i = 0; i != n; ++i)
std::swap(a[i], b[i]);
}
此模板可确保两个参数都是相同长度的数组。
相关文章:
- 如何在C++中从两个单独的for循环中添加两个数组
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- 如何返回一个类的两个对象相加的结果
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- 如何将两个不同矢量的同一位置的两个元素组合在一起
- 两个字符串在 c++ 中不相等
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 两个文件使用彼此的功能-如何解决
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 如何确保在使用基于布尔值的两个方法之一调用方法时避免分支预测错误
- 停止cmake target_link_libraries将插件中静态库的两个对象文件链接到静态库本身
- 将fold表达式与std::一起用于两个元组
- 如何在C++中比较两个char数组
- 给定两个偶数,求出它们之间所有偶数的平方和
- 比较两个大小不等的映射c++
- 为什么两个相同的代码给出不同的输出,而它们之间的唯一区别是不同的变量名称和写作样式
- 如何使用C++引用交换两个 C 样式字符串
- 比较两个 C 样式字符串的 C++ For 循环的效率和可重复性
- 尝试将两个类似的printf样式的调试消息合并到一个函数中