-
strcmp
鎖定
strcmp函數是string compare(字符串比較)的縮寫,用於比較兩個字符串並根據比較結果返回整數。基本形式為strcmp(str1,str2),若str1=str2,則返回零;若str1str2,則返回正數。
[1-2]
- 中文名
- strcmp
- 外文名
- strcmp
- 類 別
- 庫函數
- 功 能
- 比較字符串s1和s2
- 頭文件
- string.h
- 一般形式
- strcmp(字符串1,字符串2)
strcmp語法
extern int strcmp(const char *s1,const char *s2);
strcmp説明
規則
當s1<s2時,返回為負數;
當s1=s2時,返回值= 0;
即:兩個字符串自左向右逐個字符相比(按ASCII值大小相比較),直到出現不同的字符或遇'\0'為止。如:
1."A"<"B" 2."A"<"AB" 3."Apple"<"Banana" 4."A"<"a" 5."compare"<"computer"
特別注意:strcmp(const char *s1,const char * s2)這裏面只能比較字符串,即可用於比較兩個字符串常量,或比較數組和字符串常量,不能比較數字等其他形式的參數。
ANSI標準規定,返回值為正數,負數,0 。而確切數值是依賴不同的C實現的。
[3]
和v
- 當兩個字符串不相等時,C標準沒有規定返回值會是1 或 -1,只規定了正數和負數。
- 有些會把兩個字符的ASCII碼之差作為比較結果由函數值返回。但無論如何不能以此條依據作為程序中的流程邏輯。
strcmp代碼
#include <string.h> #include <memcopy.h> #undef strcmp int strcmp(p1,p2) { const char *p1; const char *p2; register const unsignedchar *s1=(const unsignedchar*)p1; register const unsignedchar *s2=(const unsignedchar*)p2; unsigned reg_charc1,c2; do { c1=(unsigned char)*s1++; c2=(unsigned char)*s2++; if(c1=='\0') returnc1-c2; } while(c1==c2); return c1-c2; } libc_hidden_builtin_def(strcmp) //以上代碼是K&R C規範的,ASCI C的在下面 /*strcmp function*/ #include <string.h> int(strap)(const char *sl,const char *s2) { /*compare unsigned char sl[],s2[]*/ for(;*sl==*s2;++sl,++s2) if(*sl=='\0') return(0); return((*(unsignedchar*)sl<*(unsignedchar*)s2)?-1:+1); }
strcmp另外的源代碼如下: int __cdecl strcmp(const char *src,const char *dst) { int ret=0; while(!(ret = *(unsigned char *)src - *(unsigned char *)dst) && *dst) ++src,++dst; if(ret<0) ret=-1; else if(ret>0) ret=1; return(ret); }
還有一種模擬算法: int strcmp(const char * src, const char * dst) //字典序比較兩字符串大小 { int ret = 0 ; while(!(ret=*src-*dst)&&*dst) //相等且沒有結束 ++src, ++dst; return( ret ); }
strcmp源碼
int strcmp(const char *str1,const char *str2) { /*不可用while(*str1++==*str2++)來比較,當不相等時仍會執行一次++, return返回的比較值實際上是下一個字符。應將++放到循環體中進行。*/ while(*str1 == *str2) { assert((str1 != NULL) && (str2 != NULL)); if(*str1 == '\0') return 0; str1++; str2++; } return *str1 - *str2; }
strcmp示例1
#include <stdio.h> #include <string.h> int main() { char string[20]; char str[3][20]; int i; for(i=0;i<3;i++) gets(str[i]); if(strcmp(str[0],str[1])>0) strcpy(string,str[0]); else strcpy(string,str[1]); if(strcmp(str[2],string)>0) strcpy(string,str[2]); printf("\nThe largest string is%s\n",string); return 0; }
strcmp示例2
(TC中運行通過)
//strcmp.c #include <syslib.h> #include <string.h> intmain() { char *s1="Hello,Programmers!"; char *s2="Hello,programmers!"; int r; clrscr(); r = strcmp(s1,s2); if(!r) printf("s1 and s2 are identical"); else if(r<0) printf("s1 less than s2"); else printf("s1 greater than s2"); getchar(); return 0; }
strcmpphp應用示例
示例:
<?php $var1="Hello"; $var2="Hello"; if(strcmp($var1,$var2)==0) {echo'相等'; } else { echo'不相等'; } ?>
int strcasecmp(string$str1,string$str2)
- str1
- 第一個字符串。
- str2
- 第二個字符串。
返回值: 如果 str1 小於 str2 返回 < 0; 如果 str1 大於 str2 返回 > 0;如果兩者相等,返回 0。
示例 :
<?php $var1="Hello"; $var2="hello"; if(strcasecmp($var1,$var2)==0){ echo'$var1isequalto$var2inacase-insensitivestringcomparison'; } ?>
- 參考資料
-
- 1. 張建輝,葉剛 .腦動力 PHP函數速查效率手冊:電子工業出版社 , 2012.10
- 2. 張權. Objective-C函數速查實例手冊:人民郵電出版社, 2014.2
- 3. 陳超 . C語言常用函數速查手冊:化學工業出版社 ,2010.6
- 4. 列旭松,陳文.PHP核心技術與最佳實踐(第2版): 機械工業出版社 ,2018.9
- 5. 張建輝,葉剛 . 腦動力 PHP函數速查效率手冊: 電子工業出版社,2012.10
- 6. PHP strcmp() 函數 .W3School[引用日期2023-08-30]