C++处理字符串有两种方式,即:指针方式和数组方式
- 数组方式:char a[] = "HelloWorld";
- 指针方式:const char* s = "HelloWorld"; const可以忽略
接下来详细讲解一下字符串指针
首先,为什么字符串可以直接赋值给指针,即char* s = "HelloWorld"不会报错,不应该是把字符串的地址赋值给指针吗?
原因:这里的双引号做了3件事:
- 1.申请了空间(在常量区),存放了字符串
- 2. 在字符串尾加上了'/0'
- 3.返回地址
为什么字符串指针的指针名输出字符串内容而不是地址?
字符串指针的指针名代表字符串的首地址,但输出字符串指针名时输出的却是完整字符串,如下:
char* s = "HelloWorld";
cout<<s<<endl; //s是字符串的首地址,但却输出HelloWorld
cout<<*s<<endl; //输出H
cout<<*(s+1)<<endl; //输出e,s+1是第二个字符的地址
cout <<static_cast<void *>(s) << endl; //此时输出的才是字符串地址
原因是C++标准库中I/O类对<<操作符重载,在遇到字符型指针时会将其当作字符串名来处理,输出指针所指的字符串。既然这样,那么我们就别让它知道那是字符型指针,所以得用到强制类型转换,用static_cast把字符串指针转换成无类型指针
字符串指针指向的地址可以修改,但所指向的字符串内容不能修改,因为字符串常量是不能改变的
char* s = "HelloWorld";
s="abcd"; //合法
cout<<*(s+1)<<endl;
*(s+1)='d'; //不合法,这里虽然没报错,但这一句实际下一句并未执行
cout<<s<<endl; //未执行
字符串指针数组:
char *p[6]={"ABCD","EFGH","IJKL","MNOP"};
int i;
for(i=0;i<4;i++)
cout<<p+i<<endl; //输出指针数组中的每个指针的首地址
for(i=0;i<4;i++)
cout<<p[i]<<endl; //输出每个字符串,实际上p[i]为第i个字符串的首地址
for(i=0;i<4;i++)
cout<<*p[i]; //输出每个字符串第一个字符AEIM
cout<<endl;
for(i=0;i<4;i++)
cout<<*(p[i]+1); //输出每个字符串第二个字符BFJN