在C語(yǔ)言中比較兩個(gè)字符串是否相等的方法
C語(yǔ)言strcmp()函數(shù):比較字符串(區(qū)分大小寫(xiě))
頭文件:#include <string.h>
strcmp() 用來(lái)比較字符串(區(qū)分大小寫(xiě)),其原型為:
int strcmp(const char *s1, const char *s2);
【參數(shù)】s1, s2 為需要比較的兩個(gè)字符串。
字符串大小的比較是以ASCII 碼表上的順序來(lái)決定,此順序亦為字符的值。strcmp()首先將s1 第一個(gè)字符值減去s2 第一個(gè)字符值,若差值為0 則再繼續(xù)比較下個(gè)字符,若差值不為0 則將差值返回。例如字符串"Ac"和"ba"比較則會(huì)返回字符"A"(65)和'b'(98)的差值(-33)。
【返回值】若參數(shù)s1 和s2 字符串相同則返回0。s1 若大于s2 則返回大于0 的值。s1 若小于s2 則返回小于0 的值。
注意:strcmp() 以二進(jìn)制的方式進(jìn)行比較,不會(huì)考慮多字節(jié)或?qū)捵止?jié)字符;如果考慮到本地化的需求,請(qǐng)使用 strcoll() 函數(shù)。
【實(shí)例】對(duì) 4 組字符串進(jìn)行比較。
#include <string.h> main(){ char *a = "aBcDeF"; char *b = "AbCdEf"; char *c = "aacdef"; char *d = "aBcDeF"; printf("strcmp(a, b) : %d\n", strcmp(a, b)); printf("strcmp(a, c) : %d\n", strcmp(a, c)); printf("strcmp(a, d) : %d\n", strcmp(a, d)); }
輸出結(jié)果:
strcmp(a, b) : 32 strcmp(a, c) :-31 strcmp(a, d) : 0
C語(yǔ)言strcasecmp()函數(shù):判斷字符串是否相等(忽略大小寫(xiě))
頭文件:#include <string.h>
定義函數(shù):
int strcasecmp (const char *s1, const char *s2);
函數(shù)說(shuō)明:strcasecmp()用來(lái)比較參數(shù)s1 和s2 字符串,比較時(shí)會(huì)自動(dòng)忽略大小寫(xiě)的差異。
返回值:若參數(shù)s1 和s2 字符串相同則返回0。s1 長(zhǎng)度大于s2 長(zhǎng)度則返回大于0 的值,s1 長(zhǎng)度若小于s2 長(zhǎng)度則返回小于0 的值。
范例
#include <string.h> main(){ char *a = "aBcDeF"; char *b = "AbCdEf"; if(!strcasecmp(a, b)) printf("%s=%s\n", a, b); }
執(zhí)行結(jié)果:
aBcDeF=AbCdEf
相關(guān)文章
c++隱式類(lèi)型轉(zhuǎn)換存在的問(wèn)題解析
隱式轉(zhuǎn)換,是指不需要用戶(hù)干預(yù),編譯器私下進(jìn)行的類(lèi)型轉(zhuǎn)換行為,很多時(shí)候用戶(hù)都不知道具體進(jìn)行了哪些轉(zhuǎn)換,這篇文章主要介紹了c++隱式類(lèi)型轉(zhuǎn)換存在的陷阱,需要的朋友可以參考下2022-03-03關(guān)于C語(yǔ)言 文件讀寫(xiě) feof 函數(shù)
這篇文章主要給大家分享的是關(guān)于C語(yǔ)言文件讀寫(xiě) feof 函數(shù) ,feof 是 C 語(yǔ)言標(biāo)準(zhǔn)庫(kù)函數(shù),其功能是檢測(cè)文件結(jié)束符,如果文件結(jié)束,則返回非 0 值,否則返回 0,感興趣的小伙伴請(qǐng)跟小編一起來(lái)看看下面文章的內(nèi)容吧2021-10-10C++?JSON庫(kù)?nlohmann::basic_json::accept的用法解析
nlohmann::basic_json::accept 是 Nlohmann JSON 庫(kù)中的一個(gè)方法,它用于檢查一個(gè)字符串是否可以解析為有效的 JSON,這篇文章主要介紹了C++?JSON庫(kù)nlohmann::basic_json::accept的用法,需要的朋友可以參考下2023-06-06C語(yǔ)言 經(jīng)典題目螺旋矩陣 實(shí)例詳解
這篇文章主要介紹了C語(yǔ)言 經(jīng)典題目螺旋矩陣 實(shí)例詳解的相關(guān)資料,這里附有代碼實(shí)例及實(shí)現(xiàn)效果圖,需要的朋友可以參考下2016-12-12用C語(yǔ)言實(shí)現(xiàn)猜數(shù)字游戲
這篇文章主要為大家詳細(xì)介紹了用C語(yǔ)言實(shí)現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10C++?LeetCode0538二叉搜索樹(shù)轉(zhuǎn)換累加樹(shù)示例
這篇文章主要為大家介紹了C++?LeetCode0538二叉搜索樹(shù)轉(zhuǎn)換累加樹(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12C++?OpenCV實(shí)現(xiàn)物體尺寸測(cè)量示例詳解
本文主要介紹了利用OpenCV對(duì)物體的尺寸進(jìn)行測(cè)量,即先定位到待測(cè)物體的位置,然后測(cè)量物體的寬高。感興趣的同學(xué)可以跟隨小編一起學(xué)習(xí)學(xué)習(xí)2022-01-01基于C++實(shí)現(xiàn)的哈夫曼編碼解碼操作示例
這篇文章主要介紹了基于C++實(shí)現(xiàn)的哈夫曼編碼解碼操作,結(jié)合實(shí)例形式分析了C++實(shí)現(xiàn)的哈夫曼編碼解碼相關(guān)定義與使用技巧,需要的朋友可以參考下2018-04-04