字符串變量
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;
}