【错误记录】C++ 字符串常量参数报错 ( 无法将参数 1 从“const char [4]”转换为“char *” | 从字符串文本转换将丢失 const 限定符 )
一、报错信息
定义了一个函数 , 接收 char* 类型的 字符串参数 ;
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
}
如果传入一个字符串常量 , 如 “Hello” ,
// 传入常量字符串
fun("Hello");
完整代码如下 :
#include "iostream"
using namespace std;
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
int main() {
// 传入常量字符串
fun("Hello");
// 控制台暂停 , 按任意键继续向后执行
system("pause");
return 0;
};
报错信息 : 该报错是编译时报错 ;
Test.cpp(12,13): error C2664: “void fun(char *)”: 无法将参数 1 从“const char [6]”转换为“char *” Test.cpp(12,6): message : 从字符串文本转换将丢失 const 限定符(请参阅 /Zc:strictStrings) Test.cpp(5,6): message : 参见“fun”的声明
完整报错 :
已启动生成…
1>------ 已启动生成: 项目: HelloWorld, 配置: Debug Win32 ------
1>Test.cpp
1>D:\002_Project\006_Visual_Studio\HelloWorld\HelloWorld\Test.cpp(12,13): error C2664: “void fun(char *)”: 无法将参数 1 从“const char [6]”转换为“char *”
1>D:\002_Project\006_Visual_Studio\HelloWorld\HelloWorld\Test.cpp(12,6): message : 从字符串文本转换将丢失 const 限定符(请参阅 /Zc:strictStrings)
1>D:\002_Project\006_Visual_Studio\HelloWorld\HelloWorld\Test.cpp(5,6): message : 参见“fun”的声明
1>已完成生成项目“HelloWorld.vcxproj”的操作 - 失败。
========== 生成: 成功 0 个,失败 1 个,最新 0 个,跳过 0 个 ==========
二、问题分析
该错误 只在 高版本的 Visual Studio 中出现 , 如 Visual Studio 2017 , Visual Studio 2019 或 更高版本 ;
在 Visual Studio 2013 中 , 不会报错 ;
在 下面的 fun 函数中 , 接收一个 char* 类型的 字符数组 / 字符串 ,
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
}
如果调用时 , 传入 “Hello” 参数 , 这是 const char* 类型 , 二者的参数类型不匹配 ;
解决上述问题的思路 :
- 修改 函数参数类型 ;
- 修改 实参类型 ;
- 设置 Visual Studio 编译环境的 兼容配置 ;
三、解决方案
1、设置 Visual Studio 的兼容规则
设置 Visual Studio 的兼容规则 :
右键点击 解决方案资源管理器 中的 解决方案 , 在弹出的菜单中选择 最后一项 属性 选项 ,
打开后 , 进入到 配置属性 / C/C++ / 语言 面板中 , 查看当前的 符合模式 配置 是 " 是(/permissive-) " ,
将 符合模式 的 配置 修改为 " 否 " ,
此时程序可以正常执行 :
2、修改实参类型 ①
函数接收 char* 类型的字符串 , 那么就传入 char* 类型的实参 , 不要传入 const char* 类型的字符串 ;
将 “Hello” 字符串常量 , 强制转为 char* 类型 , 如下代码示例 :
fun((char*)"Hello");
完整代码为 :
#include "iostream"
using namespace std;
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
int main() {
fun((char*)"Hello");
// 控制台暂停 , 按任意键继续向后执行
system("pause");
return 0;
};
执行成功 :
3、修改实参类型 ②
将字符串放入 char 数组中 , 将 char 数组作为实参传递给函数 ;
char str[8] = "Hello";
fun(str);
完整代码示例 :
#include "iostream"
using namespace std;
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
int main() {
char str[8] = "Hello";
fun(str);
// 控制台暂停 , 按任意键继续向后执行
system("pause");
return 0;
};
执行成功 :
4、修改实参类型 ③
之前使用的是 C 语言中的强制类型转换 , 这里使用 C++ 中的强制类型转换 , 将 常量 转为 非常量 , 使用 const_cast 操作符进行转换 ,
fun(const_cast<char*>("Hello"));
完整代码示例 :
#include "iostream"
using namespace std;
// 接收字符串参数并打印
void fun(char* str) {
cout << str << endl;
int main() {
fun(const_cast<char*>("Hello"));
// 控制台暂停 , 按任意键继续向后执行
system("pause");
return 0;
};
执行成功 :
5、修改形参类型
将 函数中的 char* 类型的形参 , 修改为 const char* 类型 , 也可以解决该问题 ;
完整代码示例 :
#include "iostream"
using namespace std;
// 接收字符串参数并打印
void fun(const char* str) {
cout << str << endl;
int main() {
fun("Hello");