对于const char*p来说,这是个常量指针,也就是说指向常量的指针。
但是分析发现,p所指向的值并不是不能改变的,如果有程序
char str[]="greeting";
const char * p=str;
char * psr="everybody";
p=psr;
cout<<p<<endl<<*p<<endl;
则通过赋值语句将*p的值改为e,真个p所指向的字符串改为everybody。
但是如果我们直接对*p进行操作,如 *p='e';则编译出错
error C2166: l-value specifies const object
但是一个奇怪的现状就是,当我们运用赋值操作的时候,可以实现对p所指向的字符串的修改,但当使用memcpy函数时却不能实现这种效果:
const char * p=str;
char * psr="every";
cout<<psr;
memcpy(p,psr,5);
如上代码代码编译出错:
error C2664: 'memcpy' : cannot convert parameter 1 from 'const char *' to 'void *'
为此,对程序进行改动,有
const char * p=str;
const char * psr="every";
cout<<psr;
memcpy(p,psr,5);
cout<<p<<endl;
编译器还是会报出相同的错误。
以上种种可能是C++语言在实现“=”操作的时候,对类型进行了相应转换,而memcopy没有所造成的。