溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

一個(gè)string類的簡(jiǎn)單實(shí)現(xiàn)案例

發(fā)布時(shí)間:2020-09-25 03:48:32 來(lái)源:腳本之家 閱讀:152 作者:jingxian 欄目:編程語(yǔ)言

string類中使用到了賦值構(gòu)造函數(shù)、復(fù)制構(gòu)造函數(shù)、構(gòu)造函數(shù)、默認(rèn)構(gòu)造函數(shù)、析構(gòu)函數(shù)、重載操作符等一些類操作

class String
{
	public:
		String()
		{
			data = new char[1];  //這里為什么使用new char[1]呢,雖然是一個(gè)字符,這是為了和析構(gòu)函數(shù)保持對(duì)稱,因?yàn)樵趧e的構(gòu)造函數(shù)中使用的char[]
			data[0]='\0';
			length = 0;
		}
		String(const char* str)
		{
			length = strlen(str);
			data = new char[length+1];
			strcpy(data,str);
			data[length]='\0';
		}
		String(const char* str,int n)
		{
			length = n;
			data = new char[n+1];
			strncpy(data,str,n);
			data[length] ='\0';
		}
		String(const String& src) //拷貝構(gòu)造函數(shù) 也就是復(fù)制構(gòu)造函數(shù)
		{
			length = src.length;
			data = new char[length+1];
			strcpy(data,src.data);
		}
		String& operator=(const String& src) //賦值構(gòu)造函數(shù)
		{
			if(this == &src)
				return *this;
			delete [] data;
			data = new char[src.length+1];
			strcpy(data,src.data);
			return *this;
		}
		String& operator=(const char* src) //另一種的賦值構(gòu)造函數(shù)
		{
			delete [] data;
			length = strlen(src);
			data = new char[length+1];
			strcpy(data,src);
			return *this;
		}
		char& operator[](int n)
		{
			return data[n];
		}
		const char& operator[](int n) const  //對(duì)于const成員函數(shù) 最好就是返回const的引用,這樣是為了避免返回值被修改
		{
			return data[n];
		}
	friend	ostream& operator<<(ostream& os,const String& st); 
		 
		~String()
		{
			delete [] data;	
		}
	private:
		char* data;
		int length;	
};
ostream& operator<<(ostream& os,const String& st)
{
   os<<st.data;
  return os;
}

以上這篇一個(gè)string類的簡(jiǎn)單實(shí)現(xiàn)案例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI