缺點:多執行了N-1次邏輯判斷,并且打斷了循環“流水線”作業,使得編譯器不能
對循環進行優化處理,降低了效率。 優點:循環的效率高
缺點:程序不簡潔
四、有關內存的思考題(每小題5分,共20分)
void GetMemory(char p)
{
p = (char )malloc(100);
}
void Test(void)
{
char str = NULL;
GetMemory(str);
strcpy(str, "hello world");
printf(str);
}
請問運行Test函數會有什么樣的結果?
答:程序崩潰。
因為GetMemory并不能傳遞動態內存,
Test函數中的 str一直都是 NULL。
strcpy(str, "hello world");將使程序崩潰。
char GetMemory(void)
{
char p[] = "hello world";
return p;
}
void Test(void)
{
char str = NULL;
str = GetMemory();
printf(str);
}
請問運行Test函數會有什么樣的結果?
答:可能是亂碼。
因為GetMemory返回的是指向“棧內存”的指針,該指針的地址不是 NULL,但其原現的內容已經被清除,新內容不可知。
void GetMemory2(char p, int num)
{
p = (char )malloc(num);
}
void Test(void)
{
char str = NULL;
GetMemory(&str, 100);
strcpy(str, "hello");
printf(str);
}
請問運行Test函數會有什么樣的結果?
答:
(1)能夠輸出hello
(2)內存泄漏
void Test(void)
{
char str = (char ) malloc(100);
strcpy(str, “hello”);
free(str);
if(str != NULL)
{
strcpy(str, “world”);
printf(str);
}
}
請問運行Test函數會有什么樣的結果?
答:篡改動態內存區的內容,后果難以預料,非常危險。
因為free(str);之后,str成為野指針,
if(str != NULL)語句不起作用。
五、編寫strcpy函數(10分)
已知strcpy函數的原型是
char strcpy(char strDest, const char strSrc);
其中strDest是目的字符串,strSrc是源字符串。
(1)不調用C++/C的字符串庫函數,請編寫函數 strcpy
char strcpy(char strDest, const char strSrc);
{
assert((strDest!=NULL) && (strSrc !=NULL)); // 2分
char address = strDest; // 2分
while( (strDest++ = strSrc++) != ‘\0’ ) // 2分
NULL ;
return address ; // 2分
}
(2)strcpy能把strSrc的內容復制到strDest,為什么還要char 類型的返回值?
答:為了實現鏈式表達式。 // 2分
例如 int length = strlen( strcpy( strDest, “hello world”) );
六、編寫類String的構造函數、析構函數和賦值函數(25分)
已知類String的原型為:
class String
{
public:
String(const char str = NULL); // 普通構造函數
String(const String &other); // 拷貝構造函數
~ String(void); // 析構函數
String & operate =(const String &other); // 賦值函數
private:
char m_data; // 用于保存字符串
};
請編寫String的上述4個函數。
2020年河北新聞網兩學一做
時間:2023-09-18 07:0:242020年河北新聞網兩學一做
時間:2023-09-15 11:0:59兩學一做學習教育知
時間:2023-09-21 06:0:302020年開展兩學一做學習教
時間:2023-09-19 21:0:30