Bootstrap

C++ 字符串指针和字符串指针数组详解

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

;