当前位置: 代码迷 >> 综合 >> 解决C++警告:warning: conversion from string literal to 'char *' is deprecated
  详细解决方案

解决C++警告:warning: conversion from string literal to 'char *' is deprecated

热度:54   发布时间:2024-01-19 08:06:56.0

    最近几天在学习用cocos2dx开发游戏,仗着自己在上大学期间有点c语基础(考试得了96分),把C++教程草草地扫了一遍就开搞了,结果发现在编译运行的时候有很多问题都摸不着头脑,事情搞不清楚,就影响心情,索性来个刨根问底,一点一点解决掉这些乱七八糟的问题。

   今天先解决这个恶心的警告:

现有代码如下:

#include <iostream>
using namespace std;int main(int argc, const char *argv[]){char *name = "hello";cout<<name<<endl;return 0;
}

这段代码虽说可以正常运行,但用g++编译的时候报以下错误

012.cpp:21:18: warning: conversion from string literal to 'char *' is deprecated

[-Wc++11-compat-deprecated-writable-strings]

char *name = "hello";

翻译过来就是 「警告:不赞成将字符串文本转换为“char*”」

C++里面的string是const的char数组,上面的C++代码,右边是一个string,把它赋值给了左边的char数组,所以编译器会报这个警告,注意如果试图对name数组进行某一位修改:

name[0] = 'H';

编译虽然可以通过,但运行时会出现以下错误:

Bus error: 10

因为这样就相当于新建了一个"Hello"的const string,然后把它的地址复制给ss,也就相当于ss这个指针指向的内存发生了变化而已,并非试图修改原来"hello"的const string.

这个时候我们只需在类型前面加上const声明就行了。

const char *name = "Hello";

这样编译时就不会发出警告了。

虽然这种直接声明的问题解决了,但后面我在写面向对象的时候又出现了类似的问题:

代码如下:

#include <iostream>
using namespace std;class human{
public:char *name;char *address;
public:human(char *name,char *address);void set_address(char *addr);
};human::human( char *name,  char *address){this->name = name;this->address = address;
}void human::set_address(char *addr){this->address = addr;
}int main(int argc, const char *argv[]){const char *name = "hello";//  name[0] = 'H';human p(name,"beijing");cout<<p.name<<endl;cout<<p.address<<endl;p.set_address("shanghai");cout<<p.address<<endl;return 0;
}

报错信息如下:

012.cpp:25:9: error: no matching constructor for initialization of 'human'

  human p(name,"beijing");

        ^ ~~~~~~~~~~~~~~

012.cpp:13:8: note: candidate constructor not viable: 1st argument ('const char *') would lose const qualifier

human::human( char *name,  char *address){

       ^

012.cpp:4:7: note: candidate constructor (the implicit copy constructor) not viable: requires 1 argument, but 2 were

      provided

class human{

      ^

1 error generated.

解决办法如下:

在所有声明char *的地方都要加上const

修改后代码如下:

#include <iostream>
using namespace std;class human{
public:const char *name;const char *address;
public:human(const char *name,const char *address);void set_address(const char *addr);
};human::human(const char *name, const char *address){this->name = name;this->address = address;
}void human::set_address(const char *addr){this->address = addr;
}int main(int argc, const char *argv[]){const char *name = "hello";//  name[0] = 'H';human p(name,"beijing");cout<<p.name<<endl;cout<<p.address<<endl;p.set_address("shanghai");cout<<p.address<<endl;return 0;
}

编译完美通过。

  相关解决方案