strcmp

strcmp

C/C++函式,比較兩個字元串

設這兩個字元串為str1,str2,

若str1=str2,則返回零;

若str1<str2,則返回負數;

若str1>str2,則返回正數。

matlab中函式,strcmp(s1,s2) 判斷兩個字元串s1和s2是否相同,相同返回true ,不同返回false

基本介紹

  • 中文名:strcmp
  • 外文名:strcmp
  • 類別:庫函式
  • 功能:比較字元串s1和s2
  • 頭檔案string.h
  • 一般形式:strcmp(字元串1,字元串2)
原型,說明,代碼,源碼,套用舉例1,套用舉例2,使用,

原型

extern int strcmp(const char *s1,const char *s2);
strcmp

說明

規則
當s1<s2時,返回為負數;
當s1==s2時,返回值= 0;
當s1>s2時,返回正數。
即:兩個字元串自左向右逐個字元相比(按ASCII值大小相比較),直到出現不同的字元或遇'\0'為止。如:
"A"<"B" "a">"A" "computer">"compare"
特別注意:strcmp(const char *s1,const char * s2)這裡面只能比較字元串,即可用於比較兩個字元串常量,或比較數組和字元串常量,不能比較數字等其他形式的參數。
ANSI標準規定,返回值為正數,負數,0 。而確切數值是依賴不同的C實現的。
Return Value
Returns an integral value indicating the relationship between the strings:
return value<0 the first character that does not match has a lower value inptr1than inptr2
return value=0 the contents of both strings are equal
return value>0 the first character that does not match has a greater value inptr1than inptr2
  1. 當兩個字元串不相等時,C標準沒有規定返回值會是1 或 -1,只規定了正數和負數。有些實現會返回1或-1,但將返回值與1或-1做比較的人,都是不合格的程式設計師。
  2. 有些會把兩個字元的ASCII碼之差作為比較結果由函式值返回。但無論如何不能以此條依據作為程式中的流程邏輯。

代碼

#include <string.h>#include <memcopy.h>#undef strcmpint 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 );}

源碼

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;}

套用舉例1

(在VC6.0中運行通過)
#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;}

套用舉例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;}

使用

strcmp — 二進制安全字元串比較
說明
int strcmp( string $str1 , string $str2 )
注意該比較區分大小寫。
參數
str1第一個字元串。
str2第二個字元串。
返回值
如果 str1小於 str2,返回負數;如果 str1大於 str2,返回正數;二者相等則返回 0。(相等時返回0)
示例:
<?php        $var1="Hello";        $var2="Hello";                  if(strcmp($var1,$var2)==0)         {echo'相等';         }        else     {                echo'不相等';        } ?>
strcasecmp — 二進制安全比較字元串(不區分大小寫)
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'; }?>

相關詞條

熱門詞條

聯絡我們