C語言---常見的字符函數和字符串函數介紹

目錄

前言

1 字符分類函數

2 字符轉換函數

3 strlen的使用和模擬實現?

3.1 strlen的模擬實現?

4 strcpy的使用和模擬實現

4.1? strcpy的模擬實現

5 strcat的使用和模擬實現?

?5.1 strcat的模擬實現

?6 strcmp的使用和模擬實現

6.1 strcmp的模擬實現

7 strncpy函數的使用?

8 strncat函數的使用?

?9 strncmp函數的使用

10 strstr的使用和模擬實現?

10.1 strstr的模擬實現

11 strtok函數的使用?

12 strerror函數的使用?

?總結


前言

在寫C語言程序時,我們常常要處理字符和字符串,這就需要利用到字符函數和字符串函數,C語言標準庫中提供了一系列庫函數,下面就介紹一下常見的字符函數和字符串函數。

1 字符分類函數

C語言中有一些函數是做字符分類的,意思就是辨別一個字符屬于什么字符。這些函數在使用時要包含頭文件<ctype.h>

函數如果函數參數符合下列條件就返回真
iscntrl任何控制字符
isspace空白字符:空格,‘’,換頁‘\f’,換行‘\n’,回車‘\r’,制表符‘\t’,垂直制表符‘\v’
isdigit十進制數字0~9
isxdigit十六進制數字,包括所有十進制數字,小寫字母a~f,大寫字母A~F
islower小寫字母a~z
isupper大寫字母A~Z
isalpha字母a~z或A~Z
isalnum字母或者數字,a~z,A~Z,0~9
ispunct標點符號,任何不屬于數字或者字母的圖形字符(可打印)
isgraph任何圖形字符
isprint任何可打印字符,包括圖形字符和空白字符

這些函數使用方法類似,在這里舉一個例子,其他函數使用同理:

int islower(int c);

islower是能夠判斷參數部分的c是否為小寫字母,通常通過返回值來表明:如果是小寫字母就返回非0的整數;如果不是小寫字母,則返回0。

舉例:寫一個代碼,將字符串中的小寫字母轉大寫,其他字符不變?。代碼如下:

#include <stdio.h>
#include <ctype.h>
int main()
{char str[] = "hELlO WorlD";char* p = str;while(*p != '\0'){if (islower(*p)){*p -= 32;}p++;}printf("%s\n",str);return 0;
}

輸出結果:

?

2 字符轉換函數

C語言中提供了2個字符轉換函數:

1 int tolower(int c);//將參數傳進去的大寫字母轉小寫
2 int toupper(int c);//將參數傳進去的小寫字母轉大寫

上面寫的小寫轉大寫代碼,是用-32實現的,有了轉換函數,就可以直接利用toupper實現,如下:


#include <stdio.h>
#include <ctype.h>
int main()
{char str[] = "hELlO WorlD";char* p = str;while (*p != '\0'){if (islower(*p)){*p=toupper(*p);}p++;}printf("%s\n", str);return 0;
}

3 strlen的使用和模擬實現?

在C語言中,strlen是用來求字符串長度的,語法如下:

size_t strlen(const char* str);
  • 字符串以‘\0’為結束標志,strlen函數返回的是在字符串‘\0’前面出現的函數(不包含‘\0’)。
  • 參數指向的字符必須以‘\0’結束。
  • 注意函數的返回值是size_t,是無符號的。
  • strlen的使用需要包含頭文件<string.h>。

?下面看一段代碼:

#include <stdio.h>
#include <string.h>
int main()
{const char* str1 = "abcdef";const char* str2 = "bbb";if (strlen(str2) - strlen(str1) > 0){printf("str2>str1\n");}else{printf("str1>str2\n");}return 0;
}

這個代碼輸出結果是多少呢?這時候我們推測一下:str2長度是3,str1長度是6,str2長度減去str1的長度小于0,那么結果是srt1>str2,答案是這樣嗎?程序運行看一下結果:

輸出結果:

結果恰恰相反,這是因為strlen的返回值是size_t,是無符號的,返回值是一個正數?。

3.1 strlen的模擬實現?

方法一,計數法:

int my_strlen(const char* str)//計數法
{assert(str);int count = 0;while (*str != '\0'){count++;str++;}return count;
}

方法二,指針-指針:?

int my_strlen(const char* str)//指針-指針
{assert(str);char* p = str;while (*str != '\0'){str++;}return str - p;
}

方法三 ,遞歸法:

int my_strlen(const char* str)//遞歸法
{assert(str);if (*str == '\0')return 0;elsereturn 1+my_strlen(str+1);
}
int main()
{char str[] = "hello world";int ret=my_strlen(str);printf("%d\n", ret);return 0;
}

4 strcpy的使用和模擬實現

基本語法:

char* strcpy(char* destination,const char* source)
  • 將source指向的字符串復制到destination指向的數組中,包括終止字符(并在該點停止)。
  • 源字符必須以‘\0’結束。
  • 會將源字符串中的‘\0’拷貝到目標空間。
  • 目標空間必須足夠大,以確保能存放字符串。
  • 目標空間必須可修改?。

?舉例:

#include <stdio.h>
int main()
{char str1[30] = "xxxxxxxxxxxx";const char str2[] = "hello world";strcpy(str1, str2);printf("%s\n", str1);return 0;
}

輸出結果:

4.1? strcpy的模擬實現

char* my_strcpy(char* dest, const char* src)
{assert(dest != NULL);assert(src != NULL);char* ret = dest;while (*dest++ = *src++){;}return ret;
}

5 strcat的使用和模擬實現?

基本語法:

char * strcat ( char * destination, const char * source );
  • 將源字符串的內容附加到目標字符串,目標字符串結束的空字符將被源字符串的第一個字符覆蓋。
  • 源字符串必須以‘\0’結束。
  • 目標字符串也得有‘\0’,否則沒辦法知道追加從哪里開始。
  • 目標空間必須有足夠大,能容納下源字符串的內容。
  • 目標空間必須可以修改。

舉例:

#include <stdio.h>
int main()
{char str1[30] = "xxxxxxxxxxxx";const char str2[] = "hello world";strcat(str1, str2);printf("%s\n", str1);return 0;
}

輸出結果:

?5.1 strcat的模擬實現

char* my_strcat(char* dest, const char* src)
{assert(dest != NULL);assert(src != NULL);char* ret = dest;while (*dest){dest++;}while (*dest++ = *src++){;}return ret;
}

?6 strcmp的使用和模擬實現

基本語法:

int strcmp ( const char * str1, const char * str2 );
  • 函數從兩個字符串的首字符開始逐對比較。如果字符相同,則繼續比較后續字符,直到遇到字符差異或終止空字符為止。?
  • 第一個字符串大于第二個字符串,則返回大于0的數字。
  • 第一個字符串等于第二個字符串,則返回0。
  • 第一個字符串小于第二個字符串,則返回小于0的數字。
  • 判斷兩個字符串的大小,比較兩個字符串中對應位置上字符ASCII碼值大小。

6.1 strcmp的模擬實現

#include <stdio.h>
#include <assert.h>
int my_strcmp(const char* str1, const char* str2)
{assert(str1 && str2);while (*str1 == *str2){if (*str1 == '\0')return 0;str1++;str2++;}return *str1 - *str2;
}
int main()
{char str1[] = "hello world";char str2[] = "hello type";int ret = my_strcmp(str1, str2);printf("%d", ret);return 0;
}

7 strncpy函數的使用?

基本語法:

 char * strncpy ( char * destination, const char * source, size_t num );
  • 這個函數將源字符串的前 num 個字符復制到目標位置。如果在復制完 num 個字符之前遇到源字符串的結尾(以空字符為標志),則目標位置將用零填充,直到總共寫入 num 個字符為止。?
  • 拷貝num個字符從源字符串到目標空間。
  • 如果源字符串的長度小于num,則拷貝完源字符串之后,在目標的后邊追加0,直到num個。

8 strncat函數的使用?

?基本語法:

char * strncat ( char * destination, const char * source, size_t num );
  • 將源字符串指向字符串的前num個字符追加到目標字符串的結尾,再追加一個\0字符。
  • 如果源字符串指向的字符串的長度小于num時,只會將字符串中到\0的內容追加到目標字符串的末尾。

?9 strncmp函數的使用

基本語法:

int strncmp ( const char * str1, const char * str2, size_t num );

比較str1和str2的前num個字符,如果相等則繼續往后比較,最多比較num個字母,如果提前發現不一樣,就提前結束,大的字符所在的字符串大于另外一個。如果num個字符都相等,返回0。

10 strstr的使用和模擬實現?

?基本語法:

char * strstr ( const char * str1, const char * str2);
  • 函數返回字符串str2在字符串str1中第一次出現的位置。
  • 字符串的比較匹配不包含\0字符,以\0作為結束標志。
#include <stdio.h>
#include <string.h>
int main()
{char str1[] = "abbcbbcdefbbcdef";char str2[] = "bbcdefb";char* ret = strstr(str1, str2);printf("%s\n", ret);return 0;
}

輸出結果:

10.1 strstr的模擬實現

#include <stdio.h>
#include <assert.h>
char* my_strstr(const char* str1, const char* str2)
{assert(str1 && str2);const char* p = str1;const char* s1 = NULL;const char* s2 = NULL;if (*str2 == '\0')//檢查空字符串return (char*) str1;while (*p){s1 = p;s2 = str2;while (*s1!='\0' && *s2 != '\0' && *s1 == *s2){s1++;s2++;if (*s2 == '\0')return (char*) p;}p++;}return(NULL);
}
int main()
{char str1[] = "abbcbbcdefbbcdef";char str2[] = "bbcdefb";char* ret = my_strstr(str1, str2);printf("%s", ret);return 0;
}

11 strtok函數的使用?

?基本語法:

char * strtok ( char * str, const char * sep);
  • sep參數指向一個字符串,定義了一個用作分隔符的字符集合。
  • 第一個參數指定一個字符串,它包含了0個或者多個由sep字符串中一個或者多個分隔符分割的標記。
  • strtok函數找到str中的下一個標記,并將其用\0結尾,返回一個指向這個標記的指針。strtok會改變操作的字符串,所以在使用strtok函數切分的字符串一般都是臨時拷貝的內容,并且可以修改。
  • strtok函數第一個參數不為NULL時,函數將找到str中第一個標記,strtok函數將保存它在字符串中位置。
  • strtok函數第一個參數為NULL時,函數將在同一個字符串中被保存的位置開始,查找下一個標記。
  • 如果字符串中不存在更多的標記,返回NULL指針。

舉例:

#include <stdio.h>
#include <string.h>
int main()
{char arr[] = "192.168.11.22";char* str = NULL;char* sep = ".";for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep)){printf("%s\n", str);}return 0;
}

?輸出結果:

12 strerror函數的使用?

?基本語法:

char * strerror ( int errnum );

strerror函數可以把參數部分錯誤碼對應的錯誤信息的字符串地址返回來。

在不同的系統和C語言標準庫的實現中都規定了?些錯誤碼,?般是放在 <errno.h> 這個頭文件中說明的,C語言程序啟動的時候就會使用?個全面的變量errno來記錄程序的當前錯誤碼,只不過程序啟動的時候errno是0,表示沒有錯誤,當我們在使用標準庫中的函數的時候發生了某種錯誤,就會將對應的錯誤碼存放在errno中,一個錯誤碼的數字是整數很難理解是什么意思,所以每?個錯誤碼都是有對應的錯誤信息的。strerror函數就可以將錯誤對應的錯誤信息字符串的地址返回。下面編寫代碼打印錯誤信息:

#include <stdio.h>
#include <string.h>
#include <errno.h>
int main()
{int i = 0;for (i = 0; i <= 10; i++){printf("%d  %s\n", i,strerror(i));}return 0;
}

輸出結果:

?總結

本文介紹了常見的字符函數和字符串函數,希望對你有用,如果這篇文章對你有用,可以點點贊哦,你的支持就是我寫下去的動力,后續會不斷地分享知識。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88949.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88949.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88949.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Minio入門+適配器模式(實戰教程)

一、安裝Minio 1.1 拉取鏡像 docker pull minio/minio docker images 1.2創建掛載目錄 1.2.1 創建數據目錄 mkdir -p /docker-minio/data 1.2.2 創建配置文件目錄 mkdir -p /docker-minio/config 1.2.3 設置權限 chmod -R 777 /docker-minio/data /docker-minio/config …

LLaMA-Factory 對 omnisql 進行 ppo dpo grpo nl2sql任務 實現難度 時間 全面對比

在LLaMA-Factory框架下&#xff0c;針對omnisql任務&#xff08;自然語言到SQL生成&#xff09;應用PPO、DPO、GRPO三種算法的實現難度、時間及全面對比如下&#xff1a; 一、實現難度對比 1. PPO&#xff08;近端策略優化&#xff09; 難度&#xff1a;★★☆☆☆&#xff…

Kingbase 數據庫中的 sys_guid() 函數報錯

解決 Kingbase 數據庫中的 sys_guid() 函數報錯問題 問題背景 Kingbase 數據庫在遷移或使用過程中&#xff0c;可能會遇到 select sys_guid() 函數報錯 , 提示函數不存在的情況&#xff0c;這通常是由于以下幾種原因造成的&#xff1a; 函數未正確安裝或未啟用函數參數不符合…

零基礎RT-thread第五節:電容按鍵(2)

上一章的電容按鍵完全使用的HAL庫的代碼&#xff0c;并沒有使用線程。這里嘗試使用線程來控制電容按鍵。 依舊是 F767 本來以為會很容易實現&#xff0c;沒想到嘗試了很久&#xff0c;電容按鍵一直沒有反應。 static rt_uint32_t measure_charge_time(void) {// 步驟1: 放電 …

華為云Flexus+DeepSeek征文|單機部署 與 CCE 高可用部署下 Dify 性能實測

引言 在當今的 AI 應用開發領域&#xff0c;選擇合適的部署方式對于應用的性能表現、資源利用和成本控制至關重要。華為云為開發者提供了多樣化的部署選擇&#xff0c;其中基于單機 Flexus 實例的基礎版部署和基于 CCE 容器的高可用版部署是兩種常見的方式。本文將深入對比這兩…

釘釘小程序框架:Pinia 狀態管理與持久化存儲封裝

上一篇文章完成了 Pinia 在釘釘小程序中的引入與基礎配置 文章地址&#xff1a;釘釘小程序框架引入 Pinia 狀態管理-CSDN博客 本文將深入探討如何通過Pinia 結合持久化存儲 實現用戶狀態 在上一章節中&#xff0c;我們已經完成了 Pinia 在釘釘小程序中的引入與基礎配置。本章將…

云計算產業鏈

一、云計算定義與分類體系 本質特征 按需服務模式&#xff1a;以網絡化方式提供可配置的計算資源共享池&#xff08;網絡/服務器/存儲/應用&#xff09;。核心能力&#xff1a;快速彈性擴容、資源池化共享、按使用量付費、低管理開銷。技術原理&#xff1a;通過分布式計算將大型…

git使用詳解和示例

什么是 Git&#xff1f; Git 是一個 分布式版本控制系統&#xff08;DVCS&#xff09;&#xff0c;用于跟蹤文件的變化&#xff0c;協調多人協作開發。由 Linus Torvalds 開發&#xff0c;用于管理 Linux 內核代碼。 Git 的核心概念 名稱說明工作區 (Working Directory)你看到…

深度學習的引出

雖然我們的神經?絡給出了令?印象深刻的表現&#xff0c;但這樣的表現帶有?分神秘 ?絡中的權重和偏置是被?動發現的。這意味著我們不能?即解釋?絡怎么做的、做了什么。我們能否找 到?些?法來理解我們的?絡通過什么原理分類?寫數字&#xff1f;并且&#xff0c;在知道…

GEO(生成式引擎優化)—— 內容創作者與企業的生死新戰場

在搜索引擎優化&#xff08;SEO&#xff09;定義了互聯網信息獲取規則數十年后&#xff0c;一場由生成式人工智能&#xff08;AIGC&#xff09;驅動的風暴正悄然重塑整個格局。當ChatGPT、Claude、Gemini等AI助手能夠直接生成整合后的答案&#xff0c;而非僅僅提供鏈接列表時&a…

混合密度模型GMM的似然函數(二)

設 Θ { π k , θ k } k 1 K \varTheta \{ \pi_k, \boldsymbol {\theta}_k \}_{k1}^{K} Θ{πk?,θk?}k1K?為參數向量&#xff0c; X { x 1 , ? , x n } \mathcal {X} \{ {\bm x}_1, \cdots, {\bm x}_n \} X{x1?,?,xn?}為觀測數據&#xff0c;給定數據點的獨立性&a…

selenium元素定位

當我們可以打開瀏覽器后我們如果想要進行web測試我們自然要對網頁的一些功能進行單獨拿出來進行測試&#xff0c;但是我們要怎么才能拿到我們想要的元素&#xff0c;并且對其進行操作呢。 我們就以百度主頁的輸入框為例&#xff0c;如果我們想要王輸入框中輸入一些內容我們就需…

2025第十五屆上海生物發酵展:江蘇健達干燥盛裝赴會

2025 年 8 月 7 - 9 日&#xff0c;上海新國際博覽中心將迎來一場生物發酵行業的盛會 —— 第 15 屆上海國際生物發酵產品與技術裝備展覽會&#xff08;BIOCHINA 2025&#xff09;。作為國內干燥設備領域的領軍企業&#xff0c;江蘇健達干燥工程有限公司受邀盛裝參展&#xff0…

【效率工具】單機游戲修改方案:輕量管理器+全能平臺組合

大家好&#xff01;今天我要給大家介紹兩款超級實用的軟件&#xff0c;專門為喜歡玩單機游戲的小伙伴們準備。 一、風靈月影管理器 不想滿網翻修改器&#xff1f;這個 27M 的小工具直接幫你一鍵搞定&#xff0c;這款軟件是由B站UP鴉無量 開發。 收錄上千款游戲補丁&#xff0c;…

七天學會SpringCloud分布式微服務——01——基礎概念

重點是復習體系&#xff0c;從今天6.24開始&#xff0c;確保轉化為自己的東西心平氣和&#xff0c;腳踏實地學習的是尚硅谷微服務 1、從單體架構到集群架構再到分布式架構 單體架構 就是 所有的功能&#xff08;服務&#xff09;模塊 都部署在同一臺服務器&#xff08;一臺服…

三分鐘學會利用deepseek將復雜信息轉換成可視化圖表

數據可視化是傳達復雜信息的重要手段。通過將數據轉化為直觀的圖表、圖形和交互式界面,我們可以更高效地理解信息、發現趨勢并做出決策。對于普通人來說,要將數據可視化可謂千難萬難。但在AI工具飛速發展的今天,這個過程將會變得非常簡單。今天分享的內容就是如何使用生成式…

PDF處理控件Spire.PDF系列教程:Python中快速提取PDF文本、表格、圖像及文檔信息

在 Python 中讀取 PDF 文檔是實現文檔自動化、內容分析和數據提取的基礎操作之一。無論你處理的是合同、報告、發票&#xff0c;還是科研論文&#xff0c;能夠通過代碼訪問 PDF 內容&#xff0c;不僅能節省時間&#xff0c;還能帶來更高效的處理流程。 要在 Python 中準確提取…

微軟人工智能證書AI-102 | 如何快速通過?

微軟 AI-102 考試&#xff0c;全稱 “Designing and Implementing a Microsoft Azure AI Solution”&#xff0c;是微軟推出的用于驗證考生在 Azure 平臺上設計和實施 AI 解決方案核心能力的認證考試。以下是具體介紹&#xff1a; 考試描述&#xff1a; 考試主要衡量考生實施計…

github使用指南

1、生成SSH密鑰對 ssh-keygen -t ed25519 -C "你的github郵箱"然后根據提示保存路徑&#xff0c;設置密碼 2、將公鑰添加到github cat ~/.ssh/id_ed25519.pub復制輸出內容。 在gihub中點擊New SSH Key&#xff0c;添加密鑰 3、配置git使用SSH地址 git remote se…

AD22以上的基礎操作

1.檢測創建的原理圖器件庫 2.原理圖頁加大 Size&#xff1a;常規和自定義 推薦可視化柵格100mil 快捷鍵VG 3.原理圖器件器件號排序 自動排序&#xff1a;快捷鍵TAA 先解鎖 4.BOM(Bill of Material)物料表導出 description描述&#xff1a;類似精度。 導出各種類型bom表 5…