const char* 和char* 之间的转换

const char*是指向常量的指针,而不是指针本身为常量,可以不被初始化.该指针可以指向常量也可以指向变量,只是从该指针的角度而言,它所指向的是常量,

通过该指针不能修改它所指向的数据.

1.const char是不能直接赋值到char的,这样编译都不能通过,理由:假如可以的话,那么通过char就可以修改const char指向的内容了,这是不允许的.所以char要另外开辟新的空间。

include <iostream>

using namespace std;
void main(){
const char* cpc="abcde";
char* pc=new char[100];
strcpy(pc,cpc);
cout<<pc<<endl;
}
2.char到 const char直接赋值就可以了

const char* cpc;

char* pc="abcde";

cpc=pc;

二、指针常量,常量指针

1. 什么是指针常量?指针常量即指针类型的常量。

例:char *const name1="John";

name1="abc"; //错误,name1指针,不能变,一个指针类型的变量,存放的是地址,所以不能把'"abc"的地址赋给name1
char * name2= name1; //可以

2. 什么是常量指针?常量指针即是指向常量的指针,指针的值可以改变,指针所指的地址中的内容为常量不能改变,

例:const char *name1="John";

char s[]="abc"; name1=s; //正确,name1存放的地址可以改变
char * name2= name1; //不可以,因为name2 和 name1存放的是同一块地址,如果name2地址中的内容改了,则name1的内容也改了,那么name1就不再是指向常量的指针了。


const char*, char const*, char*const 的区别

Bjarne在他的The C++ Programming Language里面给出过一个助记的方法:把一个声明从右向左读

char * const cp; ( * 读成 pointer to )
cp is a const pointer to char const char * p;
p is a pointer to const char; char const * p;

同上因为C++里面没有const*的运算符,所以const只能属于前面的类型。

C++标准规定,const关键字放在类型或变量名之前等价的。

const int n=5;    //same as below
int const m=10; const int *p; //same as below const (int) * p
int const *q; // (int) const *p char ** p1;
// pointer to pointer to char
const char **p2;
// pointer to pointer to const char
char * const * p3;
// pointer to const pointer to char
const char * const * p4;
// pointer to const pointer to const char
char ** const p5;
// const pointer to pointer to char
const char ** const p6;
// const pointer to pointer to const char
char * const * const p7;
// const pointer to const pointer to char
const char * const * const p8;
// const pointer to const pointer to const char

说到这里,我们可以看一道以前Google的笔试题:

const char *p="hello";      
foo(&p); // 函数foo(const char **pp)下面说法正确的是[]
  • A.函数foo()不能改变p指向的字符串内容。
  • B.函数foo()不能使指针p指向malloc生成的地址。
  • C.函数foo()可以使p指向新的字符串常量。
  • D.函数foo()可以把p赋值为 NULL。

至于这道题的答案是众说纷纭。针对上面这道题,我们可以用下面的程序测试:

#include <stdio.h>
#include <stdlib.h>
#include <stdio.h>
void foo(const char **pp)
{
// *pp=NULL;
// *pp="Hello world!";
*pp = (char *) malloc(10);
snprintf(*pp, 10, "hi google!");
// (*pp)[1] = 'x';
}
int
main()
{
const char *p="hello";
printf("before foo %s/n",p);
foo(&p);
printf("after foo %s/n",p);
p[1] = 'x';
return;
}

结论如下:
  1. 在foo函数中,可以使main函数中p指向的新的字符串常量。
  2. 在foo函数中,可以使main函数中的p指向NULL。
  3. 在foo函数中,可以使main函数中的p指向由malloc生成的内存块,并可以在main中用free释放,但是会有警告。但是注意,即使在foo中让p指向了由malloc生成的内存块,但是仍旧不能用p[1]='x';这样的语句改变p指向的内容。
  4. 在foo中,不能用(*pp)[1]='x';这样的语句改变p的内容。

所以,感觉gcc只是根据const的字面的意思对其作了限制,即对于const char*p这样的指针,不管后来p实际指向malloc的内存或者常量的内存,均不能用p[1]='x'这样的语句改变其内容。但是很奇怪,在foo里面,对p指向malloc的内存后,可以用snprintf之类的函数修改其内容。

最新文章

  1. Ruby的模型关系随笔
  2. PAT 1040. 有几个PAT(25)
  3. CSS权威指南 - 浮动和定位 2
  4. c语言中用宏定义一个常量,数字后面带个U, L, F的含义
  5. 【Jetlang】一个高性能的Java线程库
  6. ccrendertexture
  7. QListWidget的QComboBox下拉列表添加复选框及消息处理
  8. 读取上传的CSV为DataTable
  9. Hudson安装配置、部署应用及分析
  10. APP Store开发指南
  11. loj 3090 「BJOI2019」勘破神机 - 数学
  12. Docker CE 各安装方法
  13. This is a DynamicProxy2 error:
  14. layui前端框架
  15. 将python环境打包成.txt文件
  16. Ajax的课外了解
  17. linux串口编程参数配置详解(转)
  18. sqlserver 判断各种不存在
  19. IP等级
  20. KnockoutJs学习笔记(一)

热门文章

  1. 【二分答案】CF1613 C. Poisoned Dagger
  2. oracle 拆分字符串
  3. mysql 执行报错:Error querying database. Cause: java.sql.SQLSyntaxErrorException:which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
  4. linux系统下安装dubbo-admin
  5. 搭建mybatis开发环境
  6. kubernetes list/watch设计原理
  7. IDE常用插件
  8. C++STL标准库学习笔记(一)sort
  9. Jenkins备份
  10. 一文详解 纹理采样与Mipmap纹理——构建山地渲染效果