【C/C++】const char *、char const * 与 char const * 的区别

c/c++关于三者的定义方式:

  • const char * ptr
  • char const * ptr
  • char * const ptr

    const关键字本身用于它限定一个变量不允许被改变,产生静态作用。

1、const char * ptr / char const * ptr

      这两种用法的效果相同,都是用于定义一个指向字符常量的指针。ptr在这里指向 char * 类型常量,即 * ptr 所指向的对象为const,简单理解就是不能通过 * ptr 来修改这个对象,但如果这个对象预先被定义(例如下例所示预先被定义为 str[] 数组形式),那么可以通过其原始定义方式来修改这个对象。但是指针 ptr 本身的值是可以修改的。

      测试代码如下:

#include <iostream>

using namespace std;

int main()
{
    int i;
    char str[] = "hello world";
    char sss[] = "goood jobbb";
    char const *ptr = str;
    //const char * ptr = str'; 上下效果一样
    for(i=0; i<11; i++)
        cout << ptr[i];
    cout << endl;

    //ptr[0] = 's'; 报错,提示*ptr为只读对象
    //可通过str[]来修改,但是不能通过*ptr
    str[0] = 'g';
    for(i=0; i<11; i++)
        cout << ptr[i];
    cout << endl;

    ptr = sss;
    for(i=0; i<11; i++)
        cout << ptr[i];
    cout << endl;
}

      运行结果如下:

2、char * const ptr

      定义了一个指向字符的指针常数,即const指针,ptr本身的值不能被修改(即指针存储的地址是固定的),但是其指向的值可以被修改。

      测试代码如下:

#include <iostream>

using namespace std;

int main()
{
    int i;
    char str[] = "hello world";
    char sss[] = "goood jobbb";
    char * const ptr = str;

    for(i=0; i<11; i++)
        cout << ptr[i];
    cout << endl;

    ptr[0] = 's';
    for(i=0; i<11; i++)
        cout << ptr[i];
    cout << endl;

    //ptr = sss;  报错,提示ptr为只读对象
}

      运行结果如下:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 C 语言中,const char* 和 char* 是两种不同的类型。const char* 指向的是常量字符数组,不能通过指针修改所指向的内容。char* 指向的是可变的字符数组。 如果你想将 const char* 转换成 char*,可以使用强制类型转换的语法: ``` const char* str1 = "hello"; char* str2 = (char*)str1; ``` 但是,这样的转换是不安全的,因为你可能会修改 str2 所指向的内容,而这可能会导致程序出错或意外的行为。因此,最好不要使用这种转换。 另外,C 语言中还有另一种类似的转换,就是将 const char 转换成 char。这也是不安全的,同样不建议使用。 总之,在 C 语言中,尽量不要改变常量的值,以保证程序的正确性。 ### 回答2: 将 const char* 转换成 char* 的过程涉及到类型转换和指针操作。因为 const char* 是指向常量字符的指针,而 char* 是指向字符的指针,两者的类型不同,需要进行转换。 要将 const char* 转换成 char*,需要去除指针类型的 const 修饰符。由于 const 表示不可修改,直接去除 const 修饰符可能导致出现编译错误或者 undefined behavior。为了避免潜在的问题,可以使用类型转换来实现。 例如,可以使用 const_cast 来进行类型转换,实现 const char* 到 char* 的转换。const_cast 是 C++ 中用于转换掉对象的指向常量的 const 修饰符的一种类型转换运算符。 const char* str = "Hello, World!"; // 定义一个常量字符串指针 char* ptr = const_cast<char*>(str); // 将 const char* 转换成 char* 通过上述代码,可以将 const char* str 转换成了 char* ptr。但需要注意的是,只有在确保不会修改 const char* 指向的值时,才可以进行这样的转换。否则,如果尝试修改 const_cast 转换后的指针指向的值,将导致 undefined behavior。 总之,将 const char* 转换成 char* 可以通过使用 const_cast 进行类型转换来实现,但在使用时需要注意遵循 const 对象的不可修改性原则,避免出现错误。 ### 回答3: 在C语言中,将`const char*`类型转换为`char*`类型是一个不安全的操作,因为`const`关键字表示指向的数据是只读的,无法修改。而`char*`类型表示指向可变字符的指针。 如果强制将`const char*`转换为`char*`,并且尝试修改指向的数据,将会导致未定义的行为,可能会导致程序崩溃或产生错误的结果。 在C++中,由于类型安全性的增强,不再允许直接将`const char*`转换为`char*`。这是因为C++中的`const`操作更为严格,防止意外的数据修改。 如果确实需要修改`const char*`指向的数据,可以通过以下步骤进行转换: 1. 将`const char*`拷贝到一个新的`char*`变量中。 2. 对新的`char*`变量进行修改。 下面是一个示例代码: ```c const char* str = "Hello"; char buffer[10]; // 用于存储拷贝后的字符串 strcpy(buffer, str); // 将str拷贝到buffer中 char* mutableStr = buffer; // 将buffer的地址赋给mutableStr // 修改mutableStr指向的数据 mutableStr[0] = 'h'; printf("%s\n", mutableStr); // 输出"h"ello ``` 虽然上述代码实现了将`const char*`转换为`char*`并进行修改的效果,但这种用法不是推荐的做法。因为修改只读数据可能会引发其他问题,所以在实际开发中,尽量不要进行这种类型转换和数据修改操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值