C/C++中字符串常量为什么可以赋值给char*?

本文探讨了C和C++中字符串常量的处理方式差异。在C中,字符串常量被视为char数组,可以被char*指针直接引用,但尝试修改会导致运行时错误。而在C++中,字符串常量由const char数组构成,尽管如此,为了兼容C代码,允许将其赋值给char*,但这种做法会触发警告。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、对于C来说,字符串常量是由字符构成的数组,比如“hello”类型为char[6],所以在C中可以直接字符串常量赋值给char*。既然C中字符串不是常量,是不是可以改变字符串常量的值呢?答案是否定的,虽然可以编译通过(会有警告),但是运行时会出错。因为字符串常量位于只读存储区不允许写操作。实验如下:

#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>

int main(int argc,char*argv[])
{
    printf("running \n");

    char *p = "hello";

    printf("%s\n", p);
    
    *p = "d";//改变p所指向的内存的值,即改变"hello",所以运行会出错
    //p = "d";//只是改变了指针的指向,所以可以运行

    printf("%s\n", p);

    system("pause");
    return 0;
}

在vscode中编译如下:

虽然出现了警告,但编译成功了。

运行结果如下:

程序在运行到*p = "d"时停止了。

2、但是对于C++来说,字符串常量是由常量字符构成的数组。比如"hello"类型是const char[6]。一般来说,const char *是不能转换成char *的,因为这样会删除底层const。但是这里为了兼容C代码做了特殊处理,所以允许将字符常量赋值给char*。

 

===》》》参考https://www.zhihu.com/question/20362192

 

### C++ 中 `char` 类型字符串赋值给 `char*` 指针的方法 在C++中,可以采用多种方法将字符数组或字符串常量赋值给指向字符的指针 (`char *`)。以下是几种常见的方式: #### 使用字符串字面量初始化指针变量 可以直接通过字符串字面量来初始化一个 `char *` 变量。需要注意的是,在这种情况下创建了一个不可修改的字符串副本。 ```cpp const char* ptr = "Hello"; ``` 这里定义了一个名为 `ptr` 的常量指针并将其设置为指向 `"Hello"` 字符串的第一个字符的位置[^1]。 #### 动态分配内存并将字符串复制到新位置 如果希望拥有可变的数据,则需先调用 `new[]` 来获取足够的空间存储目标字符串的内容,再利用标准库函数如 `strcpy()` 或者更安全的选择 `strncpy()`, 将源数据拷贝过去: ```cpp #include <cstring> // For strcpy and strlen functions // Allocate memory dynamically based on the length of source string plus null terminator. size_t size_needed = std::strlen(source_string) + 1; char* dynamic_ptr = new char[size_needed]; std::strcpy(dynamic_ptr, source_string); // Remember to free allocated memory when done using it. delete [] dynamic_ptr; ``` 此代码片段展示了如何动态地分配适当大小的空间用于保存来自另一个已存在的字符串,并确保正确处理终止零(`'\0'`)的存在。 #### 利用智能指针管理资源生命周期 为了更好地控制对象的生命期以及防止潜在的泄漏问题,推荐使用现代C++特性——智能指针(例如 `unique_ptr<char[]>`)。这样可以在不需要手动释放的情况下自动回收不再使用的堆上分配的对象。 ```cpp #include <memory> #include <string> auto smartPtr = std::make_unique_for_overwrite<char[]>(source.size() + 1); std::copy_n(source.c_str(), source.size() + 1, smartPtr.get()); ``` 这段程序说明了怎样借助于模板类 `unique_ptr` 和辅助工具 `make_unique_for_overwrite` 实现相同的功能,同时还提供了更好的安全性保障[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值