皮皮网

【dubbo 服务暴露源码】【uc源码】【dts源码】strcmp 源码分析

2024-12-25 15:23:22 来源:spring batch admin源码

1.strcmp函数源码
2.strcmp函数的源码用法是怎样?
3.C语言函数strcmp(),strcat(),strstr()实现 谢谢
4.编写程序scomp(char*s1,char*s2)

strcmp 源码分析

strcmp函数源码

       strcmp函数源码实现了一个字符串比较功能,用于比较两个字符串是分析否相等。

       函数以两个参数开始:src和dst,源码分别代表要比较的分析两个字符串。

       函数首先定义了一个整型变量ret,源码用于存储比较结果。分析dubbo 服务暴露源码

       通过while循环,源码程序逐字符地比较src和dst字符串的分析对应字符。循环条件是源码当ret不等于0且dst和src不为空字符串时继续比较。

       在循环内部,分析通过*(unsigned char *)src和*(unsigned char *)dst获取src和dst当前字符的源码无符号字符表示。通过两者相减,分析得到当前字符的源码uc源码ASCII值差值。

       如果差值小于0,分析说明src当前字符小于dst,源码返回-1。如果差值大于0,说明src当前字符大于dst,返回1。dts源码否则,说明当前字符相同,继续比较下一个字符。

       当src和dst遍历完所有字符后,跳出循环。如果此时ret仍等于0,壁纸源码说明src和dst完全相等,函数返回0。如果ret小于0,说明src字符串提前结束,函数返回-1。如果ret大于0,方维源码说明dst字符串提前结束,函数返回1。

       总之,strcmp函数通过逐字符比较两个字符串,最终确定它们之间的关系。

strcmp函数的用法是怎样?

       函数简介

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

       所在头文件:string.h

       功能:比较字符串s1和s2。

       一般形式:strcmp(字符串1,字符串2)

       说明:

       当s1<s2时,返回为负数 注意不是-1

       当s1==s2时,返回值= 0

       当s1>s2时,返回正数 注意不是1

       注:c++ 中

       当s1<s2时,返回为负数 注意不是-1

       当s1==s2时,返回值等于0

       当s1>s2时,返回正数 注意不是1

       即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止。如:

       "A"<"B" "a">"A" "computer">"compare"

       特别注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。

       一例实现代码:

       #include <string.h>

       #include <memcopy.h>

       #undef strcmp

       int strcmp (p1, p2)

       {

        const char *p1;

        const char *p2;

        {

        register const unsigned char *s1 = (const unsigned char *) p1;

        register const unsigned char *s2 = (const unsigned char *) p2;

        unsigned reg_char c1, c2;

        do{

        c1 = (unsigned char) *s1++;

        c2 = (unsigned char) *s2++;

        if (c1 == '\0')

        return c1 - c2;

        }while (c1 == c2);

        return c1 - c2;

       }

       libc_hidden_builtin_def (strcmp)

       c的实现方式:

       int mystrcmp(const char*s1,const char*s2){

        while(*s1!=0&&*s2!=0&&*s1==*s2){

        s1++;

        s2++;

        }

        return *s1-*s2;

       }

       2函数源码

       int strcmp(const char *str1, const char *str2){ while (*str1==*str2) { if(*str1=='\0') return 0; str1++; str2++; } return *str1-*str2;}

       应用举例举例1

       (在VC6.0中运行通过)

       #include<stdio.h>

       #include<string.h>

       void main()

       {

        char string[];

        char str[3][];

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

       }

       说明

       intstrcmp( string$str1 , string$str2 )

       注意该比较区分大小写。

       参数

       str1第一个字符串。

       str2第二个字符串。

       返回值

       如果 str1小于 str2,返回负数;如果 str1大于 str2,返回正数;二者相等则返回 0。(相等时返回0)

C语言函数strcmp(),strcat(),strstr()实现 谢谢

       int strcmp(char *s,char *t)

       {

       while(*s==*t&&*s){ s++;t++;}

       return *s-*t;

       }

       char *strcat(char *s,char *t)

       {

       char *p=s;

       while(*p) p++;

       while(*p++=*t++)

       return s;

       }

       char *strstr(char *s,char *t)

       {

        char *p1,*p2;

        while(*s)

        {

         for(p1=s,p2=t;*p1==*p2&&*p2;p1++,p2++);

         if(*p2=='\0') return(s);

         s++;

        } 

       return NULL;

       }

编写程序scomp(char*s1,char*s2)

       è¿™æ˜¯C语言标准库函数strcmp的源码:

       int 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 );

       }