strcpy函式的實現

2021-06-28 13:14:53 字數 1124 閱讀 6993

大家一般認為名不見經傳strcpy函式實現不是很難,流行的strcpy函式寫法是:

[cpp]view plain

copy

char

*my_strcpy(

char

*dst,

const

char

*src)    

如果注意到:

1,檢查指標有效性;

2,返回目的指標des;

3,源字串的末尾 '\0' 需要拷貝。

寫出上面實現函式就不在話下。

然而這樣的實現沒有考慮拷貝時記憶體重疊的情況,下面的測試用例就能使呼叫my_strcp函式的程式崩潰:

[cpp]view plain

copy

char

str[10]=

"abc"

;  my_strcpy(str+1,str);  

然而呼叫系統的strcpy函式程式正常執行,列印str結果為「aabc」!可見系統strcpy函式的實現不是這樣的。

strcpy的正確實現應為:

[cpp]view plain

copy

char

*my_strcpy(

char

*dst,

const

char

*src)    

memcpy函式實現時考慮到了記憶體重疊的情況,可以完成指定大小的記憶體拷貝,它的實現方式建議檢視文章「卓越的教練是如何訓練高手的?」,會獲益良多,這裡僅粘帖函式memcpy函式的實現:

[cpp]view plain

copy

void

* my_memcpy(

void

*dst,

const

void

*src,unsigned 

intcount)  

}  else

//源位址和目的位址重疊,高位元組向低位元組拷貝

}  return

ret;  

}  

兩者結合才是strcpy函式的真正實現吧。

strcpy函式的實現

感謝分享!cpp view plain copy char my strcpy char dst,const char src 如果注意到 1,檢查指標有效性 2,返回目的指標des 3,源字串的末尾 0 需要拷貝。寫出上面實現函式就不在話下。然而這樣的實現沒有考慮拷貝時記憶體重疊的情況,下面的測試...

strcpy函式的實現

strcpy函式的實現 已知strcpy函式的原型是 char strcpy char dst,const char src 實現strcpy函式 解釋為什麼要返回char 假如考慮dst和src記憶體重疊的情況,strcpy該怎麼實現 1.strcpy的實現 char strcpy char ds...

strcpy函式的實現

strcpy函式的實現 大家一般認為名不見經傳strcpy函式實現不是很難,流行的strcpy函式寫法是 cpp view plain copy char my strcpy char dst,const char src 如果注意到 1,檢查指標有效性 2,返回目的指標des 3,源字串的末尾 0...