字符串变量
string是C++标准库中声明的一个字符串类
定义字符串变量
包含头文件
#include <string>
定义字符串变量时无需指定长度
string str1;
string str2 = "china";
可对字符串中某一字符进行操作
string word = "then";//word[0]='t' word[1]='h'
//word[2]='e' word[3]='n'
word[2] = 'a'; //word中存储的是than
字符串变量的输入与输出
cin>>str1;
cout<<str1;
字符串变量的运算
用“=”实现字符串的赋值
string str1;
string str2 = "china";
str1 = str2; //此时str1与str2中存储的都是china
相当于C语言中的strcpy(string1,string2);
用“+”实现字符串连接
string s1 = "c++";
string s2 = "NB";
s1 = s1 + s2; //则s1被更新为c++NB
相当于C语言中的strcat(string 1,string 2);
用关系运算符实现字符串的比较
if(s1 > s2)
相当于if( strcmp(string1,string2) > 0 )
字符串数组
string s1[10];
string s2[3] = {"I","am","dog"};
说明:
①每个字符串元素相当于一个字符串变量。
②每个字符串元素长度可不同且长度可变化。
③每个字符串元素中存放一个字符串而不是一个字符。
④每个字符串元素中只包含字符串本身的字符而不包括“\0”。
注意:
编译系统为每个字符串变量分配固定字节数,存放字符串地址。
即 s2[0]、s2[1]、s2[2]存放的是地址
举例
比较字符串中字符个数
说明:
若str1=abcdef ; str2=xyz
则输出:xyzabcdef
string str1,str2,tmp;
cin>>str1>>str2;
if(str1>str2) {tmp=str1,str1=str2;str2=tmp;}
cout<<str1<<str2<<endl;
字符串占多少字节?
#include <iostream>
using namespace std;
int main(void)
{
string str_test1;
string str_test2 = "Hello World";
int value1, value2, value3;
value1 = sizeof(str_test1);
value2 = sizeof(str_test2);
value3 = sizeof(string);
cout<<"str_test1占 "<<value1<<" 个字节"<<endl;
cout<<"str_test2占 "<<value2<<" 个字节"<<endl;
cout<<"string占 "<<value3<<" 个字节"<<endl;
system("pause");
return 0;
}
输出结果:
str_test1占 8 个字节
str_test2占 8 个字节
string占 8 个字节
字符数组占多少字节?
string strArr1[]={"Trend","Micro","soft"};
string *p=new string[2];
p[0]= "US";
p[1]= "CN";
cout<<"sizeof(strArr1):"<<sizeof(strArr1)<<endl;
cout<<"sizeof(p):"<<sizeof(p)<<endl;
cout<<"sizeof(string):"<<sizeof(string) <<endl;
输出结果:
sizeof(strArr1):24
sizeof§:8
sizeof(string):8
==注意:sizeof(strarr1)表示该数组所占空间,相当于sizeof(string)*3,而sizeof§,指针所占的空间均为4,*p,才是其所指占用的空间。 ==
面试题
说明:程序修改题目,字符串数组中字符串变量中字符的输出
要求输出TrendMicrosoftUSCN
#include <iostream>
#include <string>
using namespace std;
int main(int argc,char * argv[])
{
string strArr1[]={"Trend","Micro","soft"};
string *p=new string[2];
p[0]= "US";
p[1]= "CN";
for(int i=0;i<sizeof(strArr1)/sizeof(string);i++)
cout<<strArr1[i]; //原题中缺少[i]
for(int i=0;i<sizeof(*p)*2/sizeof(string);i++)
cout <<p[i]; //原题中缺少[i]
cout<<endl;
}