无法将参数1从“const char [6]”转换为“char *”的解决方法

简介: 无法将参数1从“const char [6]”转换为“char *”的解决方法

       有一些C++程序在VS2017上运行会有一些错误,而在vc6.0中却能运行出来。接下来的一个程序就是我在vs2017上运行出现错误,而在vc6.0上运行出来。但我已经通过分析vs2017上错误来源解决了该问题,并以此作为分享。

实例码:

#include<iostream>
using namespace std;
class String
{
public:                                            
String() { p = NULL; }            //定义默认构造函数
String( char *str);                  //声明构造函数
void display();
private:
char *p;                                 //字符型指针,用于指向字符串
};
String::String( char *str)                //定义构造函数
{
p = str;                                  //使p指向实参字符串
}
void String::display()
{
cout << p;
}
int main()
{
String string1("Helle");
String string2("Book");
string1.display(); 
cout << endl;
string2.display();
cout << endl;
return 0;
}

在vs2017运行会显示

从vs2017显示的错误中看出,把形参改为常指针的话,就可以与实参相匹配了,所以可以把源程序改如下:

#include<iostream>
#include<string>
using namespace std;
class String
{
public:
String() { p = NULL; }             //定义默认构造函数
String(const char *str);          //声明构造函数,把形参定义成常指针
void display();
private:
const char *p;                        //定义成常对象成员,用于指向字符串
};
String::String(const char *str)        //定义构造函数
{
p = str;                                   //使p指向实参字符串
}
void String::display()
{
cout << p;
}
int main()
{
String string1("Helle");
String string2("Book");
string1.display(); 
cout << endl;
string2.display();
cout << endl;
return 0;
}

这样就能在vs2017成功运行出来了

相关文章
C++ --- error C2664: “LoadLibraryW”: 不能将参数 1 从“const char *”转换为“LPCWSTR”
C++ --- error C2664: “LoadLibraryW”: 不能将参数 1 从“const char *”转换为“LPCWSTR”
256 0
|
3月前
|
C++
E0144 “const char *“ 类型的值不能用于初始化 “char *“ 类型的实体
E0144 “const char *“ 类型的值不能用于初始化 “char *“ 类型的实体
|
4月前
|
C++
【C++】std::string 转换成非const类型 char* 的三种方法记录
【C++】std::string 转换成非const类型 char* 的三种方法记录
67 0
|
关系型数据库 MySQL C++
类型收窄 error C2397: conversion from ‘const int‘ to ‘char‘ requires a narrowing conversion
类型收窄 error C2397: conversion from ‘const int‘ to ‘char‘ requires a narrowing conversion
153 0
map使用const char*作为key值查找注意事项
map使用const char*作为key值查找注意事项
|
存储 关系型数据库 MySQL
面试时被这样一个问:”存储MD5值应该用VARCHAR还是用CHAR?
一个5年工作经验的小伙伴,在面试的时候被这样一个问题。说”存储MD5值应该用VARCHAR还是用CHAR“,他一时间不只如何选择,感觉用VARCHAR也可以,用CHAR也行。希望我来帮忙分析一下。
103 0
|
20天前
|
存储 数据管理 数据库
|
4月前
|
存储 关系型数据库 MySQL
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
本篇文章来讨论MySQL字段的字符类型选择并深入实践char与varchar类型的区别以及在千万数据下的性能测试
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
|
4月前
|
存储 数据库
5. CHAR和VARCHAR的区别?
`CHAR`和`VARCHAR`在数据库中有所不同:`CHAR`长度固定,用空格填充,存储效率高,英文占1字节,汉字占2字节;而`VARCHAR`长度可变,节省空间,英文和汉字都占2字节。
48 0
|
4月前
|
存储 SQL NoSQL
面试题:char和varchar的区别?
字节面试题:char和varchar的区别?
81 0