C語言的字符函數和字符串函數詳解
一、字符&字符串函數
1.strlen–求字符串長度
釋:是所求‘\0’之前的字符個數。庫函數類型-size_t(const char*)
size_t == unsigned int
#include <string.h> int main() { char arr[] = "hello world"; printf("%d\n",strlen(arr)); return 0; }
長度不受限 | 長度受限 |
strcpy | strncpy |
strcat | strncat |
strcmp | strncmp |
2.1.strcpy–拷貝字符串
庫函數類型-char* (char*, const char*)
源字符串-被拷貝字符串
釋:‘\0’是拷貝字符串終止拷貝的條件,且目標空間必須有足夠大的空間放下源字符串。
#include <string.h> int main() { char arr1[20] = { 0 }; char arr2[] = "hello world"; strcpy(arr1,arr2); printf("%s\n",arr1); return 0; }
2.2.strcat–追加字符串/鏈接字符串
庫函數類型-char* (char*, const char*)
釋:通過找到目標字符串裡的‘\0’,再將源字符追加過去
#include <string.h> int main() { char arr1[20] = "hello "; char arr2[] = "world"; printf("%s\n",strcat(arr1,arr2)); return 0; }
2.3.strcmp–字符串比較
庫函數類型-int (const char*, const char*)
釋:將左字符串與右字符串比較:小於返回小於0值,等於返回0,大於返回大於0值。
比較方式:將兩個字符串,按從左到右,一個一個字符的比較,按對應的ascll碼進行比較。
等於的情況
#include <string.h> int main() { char arr1[] = "abc"; char arr2[] = "abc"; printf("%d\n",strcmp(arr1,arr2)); return 0; }
大於的情況
#include <string.h> int main() { char arr1[] = "abc"; char arr2[] = "abd"; printf("%d\n",strcmp(arr1,arr2)); return 0; }
小於的情況
#include <string.h> int main() { char arr1[] = "abd"; char arr2[] = "abc"; printf("%d\n",strcmp(arr1,arr2)); return 0; }
2.4.strncpy–受限的字符串拷貝
庫函數類型-char* (char*, const char*,size_t)
size_t == unsigned int
釋:可以自己選擇想要拷貝的字符個數。
註:如果選擇拷貝的字符個數,大於源字符的長度,則多的部分拷貝為‘\0’
#include <string.h> int main() { char arr1[20] = "abd"; char arr2[] = "hello world"; printf("%s\n",strncpy(arr1,arr2,5)); return 0; }
2.5.strncat–受限連接字符串
庫函數類型-char* (char*,const char*,size_t)
釋:可以自己選擇想要追加/連接的字符個數。
註:如果追加的字符長度大於源字符串長度,則扔在‘\0’處就停止瞭,如果不足源字符長度,則自動追加一個‘\0’
#include <string.h> int main() { char arr1[20] = "abd "; char arr2[] = "hello world"; printf("%s\n",strncat(arr1,arr2,5)); return 0; }
2.6.strncmp–受限的比較字符串
函數庫類型-int (const char*,const char*,size_t)
釋:可以自己選擇想要比較的字符長度
#include <string.h> int main() { char arr1[20] = "abd "; char arr2[] = "hello world"; printf("%d\n",strncmp(arr1,arr2,5)); return 0; }
總結
本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!