在 C++ 中将 char** 类型传递给形参类型为 const char ** 或 const char * PARAMS[] 时,g++ 会报如下错误:
error: invalid conversion from 'char**' to 'const char**'
不过在 C 中只是报 warning.
1、函数原型中的 [] 表示指针,而不是数组
我们知道 main 函数的标准原型应该是 int main(int argc, char *argv[]); argc 是命令行参数的个数。而 argv 是一个指向指针的指针,为什么不是指针数组呢?因为前面讲过,函数原型中的[]表示指针而不表示数组,等价于 char **argv 。那为什么要写成 char *argv[] 而不写成 char **argv 呢?这样写给读代码的人提供了有用信息,argv 不是指向单个指针,而是指向一个指针数组的首元素。数组中每个元素都是 char * 指针,指向一个命令行参数字符串。(Linux C编程一站式学习,6. 指向指针的指针与指针数组,http://akaedu.github.io/book/ch23s06.html)
2、为什么不允许将 char** 赋值给 const char**
同样一段代码分别以 C++ 方式编译和以 C 方式编译,结果是不同的:
int main()
{
const int x = 1;
int* p;
int const** q = &p; // q now points to p; this is (fortunately!) an error
*q = &x; // p now points to x
*p = 2;
}
// gcc -Wall test.c -o test
// g++ -Wall test.cpp -o test
C 方式可以通过,C++ 方式是报错的,这是 C 的一个缺陷,最后竟然修改了 const int x 的值!!!
C++ FAQ. Why am I getting an error converting a Foo** → Foo const**?
正确的做法是:const int* const * q, 这样 p 就可以赋值给 q 了。