[c++基础] const char and static const char

部分内容摘自:https://blog.csdn.net/ranhui_xia/article/details/32696669

The version with const char * will copy data from a read-only location to a variable on the stack.

The version with static const char * references the data in the read-only location (no copy is performed).

在函数内部,const char *每次调用函数时,都需要在stack上分配内存,然后将数据拷贝过来,函数退出前释放。

而static const char *,会直接访问read only的数据,无需再stack上分配内存。

 

char * const cp     : 定义一个指向字符的指针常数,即const指针

const char* p       : 定义一个指向字符常数的指针

char const* p       : 等同于const char* p

举个例子:

 1 #include <iostream>
 2 #include <cstdio>
 3 using namespace std;
 4 
 5 int main()
 6 {
 7     char ch[3] = {'a','b','c'};
 8     char* const cp = ch;
 9     printf("char* const cp: \n %c\n", *cp);
10     /* 
11     ** cp point to a fixed address
12     **
13     cp++;  //error: increment of read-only variable ‘cp’
14     printf("char* const cp: \n %c\n", *cp);
15     **
16     */
17 
18     const char ca = 'a';
19     const char* p1 = &ca;
20 
21     /* 
22     ** 2. Only const char* pointer can point to a const char
23     **
24     const char cb = 'b';
25     char* p2 = &cb; //error: invalid conversion from ‘const char*’ to ‘char*’
26     **
27     **/
28 
29     /*
30     ** 3. p1 points to a const char, the char be pointed has to be const, 
31     **    p1 can point to a different const char
32     */ 
33     printf("const char* p1: \n %c\n", *p1);
34     const char cb = 'b';
35     p1 = &cb;
36     printf(" %c\n", *p1);
37     return 0;
38 }
39 
40 /*
41 ** Output:
42 char* const cp: 
43  a
44 const char* p1: 
45  a
46  b
47 **
48 */

 

转载于:https://www.cnblogs.com/shiyublog/p/9757038.html

### 回答1: C 中 char* 转换为 const char* 可以使用强制类型转换,具体操作为: const char* p = (const char*) char_ptr; 这样就能将 char* 转换为 const char* 类型了。但请注意,这种转换不安全,因为 const char* 指向的内存不能修改,但是在转换后仍可以通过 char* 指针进行修改。 ### 回答2: 要将 C 中的 `char*` 类型转换为 `const char*` 类型,可以使用类型转换操作符进行转换。 类型转换操作符可通过将变量放在圆括号 `()` 内并在圆括号前面放置新的类型来实现。在这种情况下,我们需要将 `char*` 转换为 `const char*`,因此将 `const char*` 放在圆括号前面,`char*` 放在圆括号内。 下面是一个示例代码: ```c++ char* cStr = "Hello, World!"; // 假设已经有一个 char* 类型的变量 cStr const char* constCStr = static_cast<const char*>(cStr); ``` 这里使用了 `static_cast` 运算符来进行转换。`static_cast` 运算符可以进行各种合法的转换,包括指针类型转换。将 `char*` 类型的变量 `cStr` 作为参数传递给 `static_cast<const char*>`,并将返回的结果分配给 `const char*` 类型的 `constCStr` 变量。 然后,`cStr` 的内容将可以通过 `constCStr` 使用,但是我们将无法通过 `constCStr` 更改字符串的内容。因为 `const char*` 指向的是不可更改的字符串。 需要注意的是,这样的转换仅适用于已声明的字符串。如果尝试将 `char*` 类型的变量转换为 `const char*`,并尝试更改其中的内容,则将引发异常。 总结来说,通过使用类型转换操作符并将 `char*` 类型的变量作为参数传递给 `static_cast<const char*>`,可以将 `char*` 类型转换为 `const char*` 类型。 ### 回答3: 在C语言中,C char*可以通过强制类型转换转换为const char*。 C char*是一个指向字符的指针,可以修改所指向的字符内容。而const char*是一个指向字符的常量指针,不能修改所指向字符的内容。 例如,考虑以下示例代码: ```c #include <stdio.h> int main() { char* str = "Hello, World!"; const char* const_str = (const char*)str; printf("%s\n", const_str); return 0; } ``` 在上述代码中,`char* str`是指向字符串的指针,将其强制类型转换为`const char*`,然后赋值给`const_str`。这样就得到了一个指向常量字符的指针`const_str`。 通过将C char*强制类型转换为const char*,我们确保不能通过const char*修改原始字符串的内容,从而达到了对字符串内容的保护。 需要注意的是,虽然我们可以将char*转换为const char*,但是如果原始字符串是常量字符串(如上述示例中的"Hello, World!"),则不能对其进行修改,否则会导致未定义的行为。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值