strcpy函數用法
阿新 • • 發佈:2018-11-21
安全性 while 設置 導致 可能 檢查 strcpy_s 功能 由於
strcpy()是C中的一個復制字符串的庫函數,在C++中現在編譯器要求使用strcpy_s(),提高安全性,效果是一樣的,只是防止源串的長度比目的串的長度大,導致最終的內存越界
函數聲明及實現代碼:
char* strcpy(char*dst, const char*src)
char* strcpy(char*dst, const char *src) { if ((dst == NULL) || (src == NULL)) return NULL; char *ret = dst; //[1] while ((*dst ++= *src++) != ‘\0‘); //[2] return ret; //[3] }
1)const 修飾:源字符串參數用const修飾,防止修改源字符串;
(2)空指針檢查:源指針和目的指針都有可能會出現空指針的情況,所以應該對其進行檢查;
(3)為什麽要設置ret 指針以及返回ret指針的位置[3],由於目的指針dst已經在進行移動了,所以用輔助指針ret表明首指針;
(4)以上所示[2]處,為簡單的字符串的復制過程,正好表明strcpy函數遇到‘\0‘將會停止;
(5) [3]處返回指針類型,是因為可以連續賦值,作為左值
在C++中strcpy運行時,會提示不安全,要想實現同樣的功能,需要自己把該功能換一個名字實現相同的代碼,調用strcpy_s時,類似於賦值,直接把目的字符串的換成了源字符串,目的字符串後面的字符無法再通過數組下標獲取到,這點很奇怪,不知道是哪裏出了問題?
strcpy函數用法