无法从“const char [19]”转换为“char *”问题

在VS2017中遇到将字符串常量赋值给字符指针导致的编译错误。解决方法是在报错语句前添加`const`,但随后会遇到`reinterpret_cast`转换问题。需要使用`const_cast`去除只读属性,然后进行类型转换。
摘要由CSDN通过智能技术生成

VS2017中无法将字符串常量赋值给字符指针的问题

编写C++程序
如 char *p1 = "hello wangbaoming "; 会报错!

关于类型转换的例程:

#include <iostream>
using namespace std;

int main()
{
   
	double dPi = 3.1415926;

	//1静态的类型转换:  在编译的时 进行基本类型的转换 能替代c风格的类型转换 可以进行一部分检查
	int num1 = static_cast<int> (dPi); //c++的新式的类型转换运算符  
	int num2 = (int)dPi;				//c语言的 旧式类型转换 
	int num3 = dPi;						//隐士类型转换
	cout << "num1:" << num1 << 
当我们需要将类类型强制转换char*类型时,可以通过重载强制类型转换符来实现。在类的定义中,我们可以声明一个重载了operator char*()的成员函数,该函数将返回一个指向char类型的指针。 在重载的operator char*()函数内部,我们可以使用字符串流(ostringstream)来将类的成员变量按照需要的格式转换为字符串,并将其存储在一个动态分配的char数组中。最后,我们需要确保在适当的时候释放这个动态分配的内存,以免造成内存泄漏。 需要注意的是,在进行强制类型转换时,我们经常忽略了const修饰的要求,因此我们需要使用const_cast来去除返回值的const属性,以满足char*类型的要求。 下面是一个示例代码: ``` #include <iostream> #include <sstream> #include <string> class Person { private: std::string name; int age; char* Output; public: Person() = default; Person(std::string name, int age); Person(const Person& obj); operator char*(); ~Person() = default; }; Person::Person(std::string name, int age) { this->name = name; this->age = age; } Person::Person(const Person& obj) { this->name = obj.name; this->age = obj.age; } Person::operator char*() { std::ostringstream sstr; sstr << this->name << "的年龄为" << this->age; this->Output = new char[sstr.str().size()]; strcpy(this->Output, sstr.str().c_str()); return this->Output; } int main() { Person Person_Obj1("张三", 19); std::cout << Person_Obj1 << std::endl; } ``` 这样,我们就可以通过重载operator char*()来实现将类类型强制转换char*类型。在示例代码中,输出结果为"张三的年龄为19"。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值