您好,登錄后才能下訂單哦!
這篇文章主要講解了怎么使用vs strcpy_s()和strcat_s(),內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
在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()有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。