C++學習篇之三(字符串)

字符串變量

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;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章