繁体   English   中英

如何正确地将 char ** x 转换为 const char **

[英]How to properly cast char ** x to const char **

我有以下变量。

char **arr

然后我想对数组进行一些修改,这意味着它不能被声明为常量。

现在我有一个 function 接受const char ** arr类型的参数。 但是我无法控制这个 function 的签名。

现在,当我将arr转换为const char ** arr g++ 时会生成一个警告,即[-Werror=cast-qual]

有关更多说明,请考虑关注 MCVE:

#include<cstdio>

void print(const char** x){
    printf("%s", x[0]);
}

int main(int argc, char **argv){
    if(argc>1){
        print((const char **)argv);     
    }
     return 0;
}

//Then compile it as follow:

$ g++ -Wcast-qual test.cpp

//gives the following output:

MCVE.cpp: In function ‘int main(int, char**)’:
MCVE.cpp:5:36: warning: cast from type ‘char**’ to type ‘const char**’ casts away qualifiers [-Wcast-qual]
   const char ** q = (const char**) argv;


所以我的问题是为什么这会产生警告? 这样做有什么风险吗?

以及如何实现我想要实现的行为?

允许从char**转换为const char**提供了修改const charconst char*的漏洞。

示例代码:

const char c = 'A';

void foo(const char** ptr)
{
   *ptr = &c; // Perfectly legal.
}

int main()
{
   char* ptr = nullptr;
   foo(&ptr);  // When the function returns, ptr points to c, which is a const object.
   *ptr = 'B'; // We have now modified c, which was meant to be a const object.
}

因此,将char**转换为const char**不是安全的转换。


您可以使用

if(argc>1)
{
   const char* ptr = argv[0];
   print(&ptr);     
}

让您的代码在没有cast-qual警告的情况下编译。

如果您需要传递的不仅仅是第一个参数,则需要构造一个const char*数组并使用它。

if(argc>1)
{
   int N = <COMPUTE N FIRST>;
   const char** ptr = new const char*[N];
   for (int i = 0; i < N; ++i )
   {
      ptr[i] = argv[i];
   }

   print(ptr);

   delete [] ptr; // Make sure to deallocate dynamically allocated memory.
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM