最近看C,看到strcmp函数,对它的实现原型不很清楚,于是到网上搜。网上算法一大堆,看了很多代码后自己做了一下总结

strcmp函数是C/C++中基本的函数,它对两个字符串进行比较,然后返回比较结果,函数形式如下:

int strcmp(const char* str1, const char* str2);

其中str1和str2可以是字符串常量或者字符串变量,返回值为整形。返回结果如下规定:

① str1小于str2,返回负值或者-1(VC返回-1);                   

② str1等于str2,返回0;

③ str1大于str2,返回正值或者1(VC返回1);

strcmp函数实际上是对字符的ASCII码进行比较,实现原理如下:首先比较两个串的第一个字符,若不相等,则停止比较并得出两个ASCII码大小比较的结果;如果相等就接着 比较第二个字符然后第三个字符等等。无论两个字符串是什么样,strcmp函数最多比较到其中一个字符串遇到结束符'/0'为止,就能得出结果。strcmp算法的可以有多种,不过我觉的可以把这么多算法分为两种,一种是利用减法运算判断结果,另一种是利用比较运算(==)得出结果。

减法运算的实现的代码如下:

  1. int strcmp(const char* str1, const char* str2)
  2. {
  3. int ret = 0;
  4. while(!(ret=*(unsigned char*)str1-*(unsigned char*)str2) && *str1)
  5. {
  6. str1++;
  7. str2++
  8. }
  9. if (ret < 0)
  10. {
  11. return -1;
  12. }
  13. else if (ret > 0)
  14. {
  15. return 1;
  16. }
  17. return 0;
  18. }

这个函数要注意一下几点

①使用*(unsigned char*)str1而不是用*str1。这是因为传入的参数为有符号数,有符号字符值的范围是-128~127,无符号字符值的范围是0~255,而字符串的ASCII没有负值,若不转化为无符号数这回在减法实现时出现错误。

例如 str1的值为1,str2的值为255。

作为无符号数计算时ret = -254,结果为负值,正确

作为有符号数计算时ret = 2,结果为正值,错误

②While循环中ret=*(unsigned char*)str1-*(unsigned char*)str2) && *str1,最后与上str1也可以换成str2,因为前面已经做了相减,无论哪个先为‘\0’都会退出。因为最后与上str1是为了判断str1是否结束,即是否为‘\0’。

③这个函数没有判断参数为NULL时的情况,所以当传入NULL时程序会崩溃。网上看别人说商业化代码都会在调用strcmp前先判断是否为NULL,所以可以不用判断NULL;我在VC6上测试string.h中的strcmp(NULL,NULL),程序也会崩溃。这里可以根据实际情况来决定。

若要判断NULL按下面方法更改代码,可以在这个函数最前面加入断言

assert((NULL != str1) && (NULL != str2))

但要注意断言assert 是仅在Debug 版本起作用的宏,是在Debug时做的无害测试。若想在Release 版也可

以判断NULL,那我们必须用别的代码来判断。

可以在程序前面加入if判断

if ((NULL != str1) && (NULL != str2))

{

return 0;

}

我用CFree 5测试sting.h中的strcmp(NULL,NULL),程序返回值为0(strcmp(NULL,str1)崩溃),这里我们可以返回其他的值如 -2。

我们也可以在函数前面加入while判断

while ((NULL != str1) && (NULL != str2))

{

//strcmp实现代码

}

return 0;

利用while就可以把每个字符都进行判断。



利用比较运算(==)算法如下

  1. int strcmp(const char* str1, const char* str2)
  2. {
  3. while ((*str1) && (*str1 == *str2))
  4. {
  5. str1++;
  6. str2++;
  7. }
  8. if (*(unsigned char*)str1 > *(unsigned char*)str2)
  9. {
  10. return 1;
  11. }
  12. else if (*(unsigned char*)str1 < *(unsigned char*)str2)
  13. {
  14. return -1;
  15. }
  16. else
  17. {
  18. return 0;
  19. }
  20. }

函数注意点和上面一样,有一点要注意不要为了简洁而写成下面

  1. int strcmp(const char *str1,const char *str2)
  2. {
  3. while ((*str1) && (*str1++ == *str2++)) //这里++会引起错误
  4. {
  5. NULL;
  6. }
  7. if (*(unsigned char*)str1 > *(unsigned char*)str2)
  8. {
  9. return 1;
  10. }
  11. else if (*(unsigned char*)str1 < *(unsigned char*)str2)
  12. {
  13. return -1;
  14. }
  15. else
  16. {
  17. return 0;
  18. }
  19. }

当str1为abcd,st2为abfd时,由于判断到第三个字符时while推出,而str指针又加了1,str都指向第四个字符输出结果为0,显然这是错误的。

这个函数也可以用for来实现

  1. int strcmp(const char *str1, const char *str2)
  2. {
  3. for ( ; *str1 == *str2; str1++, str2++)
  4. {
  5. if (*str1 == '\0')
  6. return 0;
  7. }
  8. if (*(unsigned char*)str1 > *(unsigned char*)str2)
  9. {
  10. return 1;
  11. }
  12. else if (*(unsigned char*)str1 < *(unsigned char*)str2)
  13. {
  14. return -1;
  15. }
  16. //如果只返回正负的话可以用 return *(unsigned char*)str1 - *(unsigned char*)str2;
  17. }
转载链接:http://blog.csdn.net/wgenek/article/details/7257435

strcmp函数实现及分析的更多相关文章

  1. 转:strcmp函数实现及分析

    转自:strcmp函数实现及详解 strcmp函数是C/C++中基本的函数,它对两个字符串进行比较,然后返回比较结果,函数形式如下:int strcmp(constchar*str1,constcha ...

  2. 逆向 string.h 函数库 memset、strcpy、strcmp 函数

    memset 函数 函数原型:void *memset(void *str, int c, size_t n) 主要功能:复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符 ...

  3. Atitit main函数的ast分析  数组参数调用的ast astview解析

    Atitit main函数的ast分析  数组参数调用的ast astview解析 1.1. Xxcls.main(new String[]{"","bb"}) ...

  4. java String.split()函数的用法分析

    java String.split()函数的用法分析 栏目:Java基础 作者:admin 日期:2015-04-06 评论:0 点击: 3,195 次 在java.lang包中有String.spl ...

  5. strstr函数与strcmp函数

    1.strstr函数主要完成在一个字串中寻找另外一个字串 函数实现工程如下:摘自http://baike.baidu.com/link?url=RwrzOxs0w68j02J2uQs5u1A56bEN ...

  6. strcmp函数和strcpy函数

    (一)strcmp函数 strcmp函数是比較两个字符串的大小,返回比較的结果.一般形式是: i=strcmp(字符串,字符串); 当中,字符串1.字符串2均可为字符串常量或变量:i   是用于存放比 ...

  7. 自己写一个strcmp函数(C++)

    题目说明: 写一个函数,实现两个字符串的比较.即自己写一个strcmp函数,函数原型为int strcmp( char * p1, char * p2); 设p1指向字符串s1,p2指向字符串s2.要 ...

  8. strcmp函数

    strcmp函数用于c语言中两个字符串比较(只可以比较字符串,不可以比较数字) 规则 当s1>s2时,返回为正数: 当s1=s2时,返回值为0: 当s1<s2时,返回为负数: 两个字符串自 ...

  9. ffplay.c函数结构简单分析(画图)

    最近重温了一下FFplay的源代码.FFplay是FFmpeg项目提供的播放器示例.尽管FFplay只是一个简单的播放器示例,它的源代码的量也是不少的.之前看代码,主要是集中于某一个"点&q ...

随机推荐

  1. 暑假集训(1)第六弹 -----简单计算器(Hdoj1237)

    Description 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值.   Input 测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算 ...

  2. starling 中的 EventDispatcher 和 Flash中原生的 EventDispatcher

    starling 比较早之前就有开始解了,但只到最近参与一个用starling 做为框架的手游项目才真正做为一程来使用它. 项目也是刚开始搭建,在这做些笔记. 在写一个管理类时, 遇到 starlin ...

  3. x264_param_t结构

    typedef struct x264_param_t { unsigned int cpu; // CPU 标志位 int i_threads; // 并行编码多帧; 线程数,为0则自动多线程编码 ...

  4. 简单的doc命令

    cd 切换目录 dir 显示目录列表 mkdir 创建目录(mkdir) rmdir 删除空目录(rmdir test) rmdir  /s 删除非空目录(rmdir test /s) echo 创建 ...

  5. sass 入门教程

    1.引言 众所周知css并不能算是一们真正意义上的“编程”语言,它本身无法未完成像其它编程语言一样的嵌套.继承.设置变量等工作.为了解决css的不足,开发者们想到了编写一种对css进行预处理的“中间语 ...

  6. js json和对象互相转换

    http://www.jb51.net/article/44562.htm obj = JSON.parse(string) | obj = jQuery.parseJSON(str) 将JSON字符 ...

  7. 转 mysql 中sql 语句查询今天、昨天、7天、近30天、本月、上一月 数据

    转自 http://blog.csdn.net/ve_love/article/details/19685399

  8. LightOj_1317 Throwing Balls into the Baskets

    题目链接 题意: 有N个人, M个篮框, 每个人投进球的概率是P. 问每个人投K次后, 进球数的期望. 思路: 每个人都是相互独立的, 求出一个人进球数的期望即可. 进球数和篮框的选择貌似没有什么关系 ...

  9. X窗口系统的协议和架构

    转自X窗口系统的协议和架构 在电脑中,X窗口系统(常称作 X11.X)是一种以位图显示的网络透明化窗口系统.本条目详述 X11 的协议及其技术架构. X C/S模型和网络透明性 X 基于C/S模型.运 ...

  10. keybd_event函数用法

    转自不用winio,直接达到驱动级模拟键盘效果的keybd_event函数用法 键盘模拟技术是在编写游戏外挂时经常使用的技术.但是由于很多游戏采用了directinput的方式,使得发送的一般键盘消息 ...