C語言字符函數(shù)與字符串函數(shù)詳解
本章重點
重點介紹處理字符和字符串的庫函數(shù)的使用和注意事項
1.求字符串長度 strlen
2.長度不受限制的字符串函數(shù) strcpy ,strcat, strcmp
3.長度受限制的字符串函數(shù) strncpy,strncat ,strncmp
4.字符串查找 strstr,strtok
5.錯誤信息報告 strerror
6.字符操作
7.內存操作函數(shù) memcpy,memmove,memset ,memcmp
前言
C語言中對字符和字符串的處理很是頻繁,但是C語言本身是沒有字符串類型的,字符串通常放在 常量字符串 中或者 字符數(shù)組 中。 字符串常量 適用于那些對它不做修改的字符串函數(shù)。
1.strlen函數(shù)
size_t strlen ( const char * str );
- 字符串已經(jīng) '\0' 作為結束標志,strlen函數(shù)返回的是在字符串中 '\0' 前面出現(xiàn)的字符個數(shù)(不包含 '\0' )。
- 參數(shù)指向的字符串必須要以 '\0' 結束。
- 注意函數(shù)的返回值為size_t,是無符號的( 易錯 )
- 學會strlen函數(shù)的模擬實現(xiàn) (計數(shù)器、指針-指針、遞歸)
講解:
注意點1
有的編譯器可能用int來接收strlen函數(shù)的返回值會報錯,因為strlen函數(shù)返回值是size_t( unsigned int 無符號整型 )
char arr[] = "abcdef"; //錯誤示范 int sz1 = strlen(arr); //正確示范 size_t sz = strlen(arr);
注意點2
注意函數(shù)的返回值為size_t,是無符號的( 易錯 )
//3 - 8 < 0?
//strlen函數(shù)是size_t類型,是無符號的,必定大于0?。。?
int main()
{
if (strlen("abc") - strlen("abcdefgh") > 0)
{
printf("哈哈哈~~");
}
else
printf("吼吼吼!");
return 0;
}
//運行結果是 哈哈哈~~
對比代碼:
int main()
{
if ((int)strlen("abc") - (int)strlen("abcdefgh") > 0)
{
printf("哈哈哈~~");
}
else
printf("吼吼吼!");
return 0;
}
//運行結果是 吼吼吼!
2.strcpy
char* strcpy(char * destination, const char * source );

- 源字符串必須以 '\0' 結束。
- 會將源字符串中的 '\0' 拷貝到目標空間。
- 目標空間必須足夠大,以確保能存放源字符串。
- 目標空間必須可變。( 即:不能是不可修改的常量字符串 )
- 學會模擬實現(xiàn)。
講解:
注意點1:
我們發(fā)現(xiàn),copy時,將源字符串毫無保留的( 包括末尾的 '\0' )一塊copy到目標字符串中??!

注意點2:
如果源字符串中間本身就含有'\0',那么我們同樣還是取到遇見的第一個‘\0' ,不會繼續(xù)往后打印的?。?!

注意點3:
目標空間必須足夠大,以確保能存放源字符串。
//錯誤示范 //目標字符串空間太少 char arr1[] = "xxx"; char arr2[] = "hello\0abc"; strcpy(arr1, arr2);
注意點4:
目標空間必須可變。

模擬strcpy函數(shù)
代碼1:
#include<stdio.h>
#include<assert.h>
void* my_strcpy(char* dest, const char* src)
{
assert(dest && src);
char* ret = dest;
while (*src)
{
*dest = *src;
dest++;
src++;
}
*dest = '\0';
}
int main()
{
char arr1[] = "xxxxxxxxxxxxxxxx";
char arr2[] = "abc";
my_strcpy(arr1, arr2);
printf("%s", arr1);
return 0;
}
代碼2:(升級版~~)
#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
assert(dest && src);
char* ret = dest;
while (*dest++ = *src++)
{
;
}
return ret;
}
int main()
{
char arr1[] = "xxxxxxxxxxxxxxxx";
char arr2[] = "abc";
printf("%s", my_strcpy(arr1, arr2));
return 0;
}
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
VisualStudio?2015?新建C/C++項目的圖文教程
visual?studio是一個比較集成的開發(fā)平臺,本文主要介紹了VisualStudio?2015?新建C/C++項目的圖文教程,具有一定的參考價值,感興趣的可以了解一下2024-06-06
Qt5.9實現(xiàn)簡單的多線程實例(類QThread)
Qt開啟多線程,主要用到類QThread。用一個類繼承QThread,然后重新改寫虛函數(shù)run()。具有一定的參考價值,感興趣的可以了解一下2021-09-09
VSCode Linux的C++代碼格式化配置的實現(xiàn)
動格式化代碼容易出現(xiàn)錯誤,特別是當代碼量較大時,使用自動格式化可以減少這種錯誤的風險,本文主要介紹了VSCode Linux的C++代碼格式化配置的實現(xiàn),感興趣的可以了解一下2023-10-10
Qt采用線程以隊列方式實現(xiàn)下發(fā)數(shù)據(jù)
在C++中隊列是一種常用的數(shù)據(jù)結構之一,一種特殊的線性表,一般采用先進先出的方式。本文主要為大家介紹了Qt如何以隊列方式實現(xiàn)下發(fā)數(shù)據(jù),感興趣的可以了解一下2022-10-10
cocos2dx-3.10 C++實現(xiàn)滾動數(shù)字
這篇文章主要為大家詳細介紹了cocos2dx-3.10 C++實現(xiàn)滾動數(shù)字效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
如何使用C語言實現(xiàn)平衡二叉樹數(shù)據(jù)結構算法
對于判斷是否為平衡二叉樹而言,我們需要知道以下特性:是一個二叉樹也是一個二叉排序樹該樹的每個結點上的(深度)左子樹 - 右子樹的值為平衡因子(BF(Balance Factor))該樹的每一個節(jié)點的左子樹和右子樹的高度至多等于1(平衡因子只可能是-1,0,1)2021-08-08

