zoukankan      html  css  js  c++  java
  • strcmp函数实现

    原型:int strcmp(const char *str1,const char *str2)

    原理:根据大于,小于,相等分别返回正,负,零

    实现:

    int strcmp(const char* str1, const char* str2)  
    {  
        int ret = 0;  
        while(!(ret=*str1-*str2) && *str1)  
        {  
            str1++;  
            str2++  
        }  
      
      
        if (ret < 0)  
        {  
            return -1;  
        }  
        else if (ret > 0)  
        {  
            return 1;  
        }  
        return 0;  
    }  

    方法2:

    int strcmp(const char* str1, const char* str2)  
    {  
        while ((*str1) && (*str1 == *str2))  
        {  
            str1++;  
            str2++;  
        }  
      
      
        if (*str1 > *str2)  
        {  
            return 1;  
        }  
        else if (*str1 < *str2)  
        {  
            return -1;  
        }  
        else  
        {  
            return 0;  
        }    
    }  

    错误的代码:"abcd"和“abfd”会显示相等,为什么?:

    int strcmp(const char *str1,const char *str2)  
    {  
        while ((*str1) && (*str1++ == *str2++)) 
        {  
        NULL;  
        }  
      
      
        if (*str1 > *str2)  
        {  
            return 1;  
        }  
        else if (*str1 < *str2)  
        {  
            return -1;  
        }  
        else  
        {  
            return 0;  
        }   
    }  
  • 相关阅读:
    Nginx的反向代理和负载均衡
    大数据开发——Hive笔记
    Mysql-索引分析查询性能
    数据库原理-事务隔离与多版本并发控制(MVCC)
    并发编程实战--知识图谱
    并发编程实战-线程池
    并发编程实战-保证线程安全方式
    Synchronized和ReentTrantLock二者区别
    并发编程实战-J.U.C核心包
    并发编程实战-ConcurrentHashMap源码解析
  • 原文地址:https://www.cnblogs.com/litifeng/p/7465173.html
Copyright © 2011-2022 走看看