C++討厭的臨時變量什么時候產生
作者:陳太漢
是的。我們討厭產生臨時變量,因為它要占用我們的內存,消耗我們的CPU時間,讓我們的程序性能降低。但有時候它是必須的。
那討厭的臨時變量什么時候產生呢?
產生臨時變量的三種情況:一:以By Value的方式傳值;二:參數為const的類型。三:類型轉換
一:以By Value的方式傳值。
我們都知道,引用類型和指針類型傳遞的都是地址,可以直接對地址中存放的數據進行操作,
而以傳值的方式傳遞參數,就會在heap中重新分配一個臨時區域,
將實參中的數據拷貝到臨時區域中,而你對這分數據進行的任何的操作都不會影響實參的內容,因為實參跟形參只是內容相同,
分別在兩塊不同的內存中。而引用和指針操作的是同一塊內存,所以形參修改后,實參也修改了。
二:參數為const的類型。(此觀點錯誤,請看我的這篇文章:Effective C++ 類與函數的設計和申明)
因為常量是不能修改,在只需要實參中的數據,而不需對實參進行修改時,或是禁止對實參進行修改時,把形參定義為const類型,
系統會產生一個臨時變量,就能起到保護數據的作用,如在函數strlen中,修改參數的值行嗎?本來只是想得到實參的長度,結果在函數中被修改了,那得到得實參長度還是真實的嗎。
如果你程序中的數據到處都可以被修改,那是多么的可怕(所以我們討厭全局變量),所以const還是有它存在的價值。
三:類型轉換的時候會產生臨時變量。
真是糟糕啊,在用類型轉換帶來便利的同時,產生臨時變量就是我們承擔的損失。
如將一個short類型轉換成int類型,他們占用的內存不一樣,如果不產生臨時變量,那不就short類型和int類型占用的字節數不就一樣了嗎,sizeof不就坑爹了嗎
C++語言禁止為非常量引用產生臨時對象。同時證明引用類型傳參不會產生臨時變量,如char[]轉換成string會報錯,他們都是引用類型
以下是我自己寫的基本函數,練手啊,下面這些函數參數前面很多都加了const,那不是到處都在產生臨時變量嗎?我在想,我就不要const,我就不準對這些參數進行任何修改,行嗎?
誰能給我答案?我只想在不需要產生臨時變量的時候不讓它產生......跟著標準走吧。
基本函數
//如果左右兩邊的字符串相等,即指向同一塊內存,delete左邊的字符串相當于delete了這兩個字符串。
char* strcpy(char* str,constchar* source)
{
if(str==source)
{
return str;
}
if(str==NULL || source==NULL)
{
return NULL;
}
char* ptStr=str; //為了實現串聯操作
while((*str++=*source++)!=NULL);
return ptStr;
}
//參數為const類型,系統會產生一個臨時變量用于存放實參的內容,
//但如果形參不定義成const類型,如果參數的內容被修改了,那么這個函數可能就不能得到正確的值.
int strlen(constchar* str)
{
if(NULL==str)return-1;
int len=-1;
while(*(str+(++len))!='\0');
return len;
}
//指定字符第一次出現的位置
constchar* strchr(constchar* str,char c)
{
if(NULL==str)
{
return NULL;
}
while(str &&*str!=c)
{
str++;
}
if(str=='\0')
{
return NULL;
}
return str;
}
//子字符串第一次出現的位置
int strstr(constchar* str,constchar* substr)
{
if(NULL==str || NULL==substr)
{
return-1;
}
if(strlen(str)<strlen(substr))
{
return-1;
}
constchar* tmp;
int i=0;
while(*str!='\0')
{
tmp=substr;
if(*str==*tmp)
{
int j=0;
while(*str!='\0'&&*tmp!='\0'&&*(str+j++)==*tmp++);
if(*tmp=='\0')
{
return i;
}
}
str++;i++;
}
return-1;
}
//追加字符串
char* strcat(char* str,constchar* cat)
{
if(NULL==cat || NULL==str)
{
return str;
}
char* tmp=str;
while(*str)//將指針移到最后
{
str++;
}
while((*str++=*cat++)!='\0');//追加字符
str=tmp;
return str;
}
//比較字符串
int strcmp(constchar* str1,constchar* str2)
{
if(NULL==str1 && NULL==str2)
{
return0;
}
if(NULL==str1)
{
return-1;
}
if(NULL==str2)
{
return1;
}
while(*str1 &&*str2 &&*str1==*str2)
{
str1++;
str2++;
}
return*str1-*str2;
}

浙公網安備 33010602011771號