在vs 2019版本中 如果使用 strcpy()與strcat() 都會警告
大意說這個 strcpy()因為空間分配的 這個函數不安全 不建議用這個函數,strcat()也是這樣。當然錯誤c4996完全可以通過代碼 讓它不提示,但是它確實不安全 不如學習一下新函數的用法。
strcpy_s()
老的 strcpy(D,S)就是把S數組復制給D,返回D。 但是S的空間比D大的話 這就會發生錯誤。
這就是這個函數的機理strcpy_s()具體
- errno_t strcpy_s
- ( char *strDestination, size_t numberOfElements, const char *strSource );
簡單說strcpy_s(D,sizeof(S)+1,S) 把S復制給D 把S的大小也給D 返回D.
strcat_s
老的機理strcat()
新的用法
strcat_s(A,sizeof(A)+sizeof(B)+1,B) 很好理解 空間一定是兩個數組之和 再加一。
ps:下面給大家介紹下strcpy_s 和 strcat_s的用法
strcpy_s是系統的安全函數,微軟在2005后建議用一系統所謂安全的函數,這中間就有strcpy_s取代了strcpy,原來strcpy函數,就象gets函數一樣,它沒有方法來保證有效的緩沖區尺寸,所以它只能假定緩沖足夠大來容納要拷貝的字符串。所以用strcpy_s代替,下面有一個使用strcpy_s的例子:
- char source[] = "Hello world !";
- char destination[20] = {0};
- strcpy_s(destination,sizeof(destination)/sizeof(destination[0]),source);
strcpy_s是以字節為單位的參數,它用來確認緩沖區大小。這允許strcpy_s函數可以進行運行時檢查,以確定寫入的字符沒有超過目標緩沖區的邊界。所以它比strcpy好用,我還知道其他系統安全函數是在本來函數的后面加上“_s”,還有個遺憾就是用visual c++6.0沒法編譯strcpy_s函數,可能是因為他太新吧
原型聲明:extern char *strcpy(char *dest,char *src);
頭文件:string.h
功能:把src所指由NUL結束的字符串復制到dest所指的數組中。
說明:src和dest所指內存區域不可以重疊且dest必須有足夠的空間來容納src的字符串。
返回指向dest的指針。
strcat_s脫胎于strcat,用于兩個字符串的鏈接,strcat(str1,str2)直接返回新的str1.但在vs2005后,為了安全起見,重新添加了些功能和api和以前不同。比如strcat_s.為什么是安全起見呢?對于老的你添加str2的時候如果st1溢出怎么辦?很明顯這就是需要改進的地方。所以新的strcat_s規定,有三個參數,必須指定str1的大小。所以應該這么來
- char string[20]="123";
- strcat_s(string,sizeof(string),"456");
- printf("%s",string);這樣20個元素,足夠裝下123456了。
原型 extern char *strcat(char *dest,char *src);
用法 #include <string.h>
在C++中,則存在于<cstring>
頭文件中。
功能 把src所指字符串添加到dest結尾處(覆蓋dest結尾處的'\0')并添加'\0'。
說明 src和dest所指內存區域不可以重疊且dest必須有足
夠的空間來容納src的字符串。
返回指向dest的指針。
總結
到此這篇關于關于vs strcpy_s()strcat_s()用法的文章就介紹到這了,更多相關vs strcpy_s()strcat_s()用法內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/that_good/article/details/106093593