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

    strcpy函数的实现

    大家一般认为名不见经传strcpy函数实现不是很难,流行的strcpy函数写法是:

    [cpp] view plaincopy
     
    1. char *my_strcpy(char *dst,const char *src)  
    2. {  
    3.     assert(dst != NULL);  
    4.     assert(src != NULL);  
    5.     char *ret = dst;  
    6.     while((* dst++ = * src++) != '')   
    7.         ;  
    8.     return ret;  
    9. }  

    如果注意到:

    1,检查指针有效性;

    2,返回目的指针des;

    3,源字符串的末尾 '' 需要拷贝。

    写出上面实现函数就不在话下。

    然而这样的实现没有考虑拷贝时内存重叠的情况,下面的测试用例就能使调用my_strcp函数的程序崩溃:

    [cpp] view plaincopy
     
    1. char str[10]="abc";  
    2. my_strcpy(str+1,str);  


    然而调用系统的strcpy函数程序正常运行,打印str结果为“aabc”!可见系统strcpy函数的实现不是这样的。

    strcpy的正确实现应为:

    [cpp] view plaincopy
     
    1. char *my_strcpy(char *dst,const char *src)  
    2. {  
    3.     assert(dst != NULL);  
    4.     assert(src != NULL);  
    5.     char *ret = dst;  
    6.     memcpy(dst,src,strlen(src)+1);  
    7.     return ret;  
    8. }  

    memcpy函数实现时考虑到了内存重叠的情况,可以完成指定大小的内存拷贝,它的实现方式建议查看文章“卓越的教练是如何训练高手的?”,会获益良多,这里仅粘帖函数memcpy函数的实现:

    [cpp] view plaincopy
     
    1. void * my_memcpy(void *dst,const void *src,unsigned int count)  
    2. {  
    3.      assert(dst);  
    4.      assert(src);  
    5.      void * ret = dst;  
    6.      if (dst <= src || (char *)dst >= ((char *)src + count))//源地址和目的地址不重叠,低字节向高字节拷贝  
    7.      {  
    8.          while(count--)  
    9.          {  
    10.              *(char *)dst = *(char *)src;  
    11.              dst = (char *)dst + 1;  
    12.              src = (char *)src + 1;  
    13.          }  
    14.      }  
    15.      else                       //源地址和目的地址重叠,高字节向低字节拷贝  
    16.      {   
    17.          dst = (char *)dst + count - 1;  
    18.          src = (char *)src + count - 1;   
    19.          while(count--)   
    20.          {  
    21.              *(char *)dst = *(char *)src;  
    22.              dst = (char *)dst - 1;  
    23.              src = (char *)src - 1;  
    24.          }  
    25.     }  
    26.     return ret;  
    27. }  

    两者结合才是strcpy函数的真正实现吧。

  • 相关阅读:
    iPhone开发:iPad的自定义菜单项研究
    nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address
    nginx重启报找不到nginx.pid的解决方法
    解决nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed错误
    LNMP安装了哪些软件?安装目录在哪?
    SSL和SSH有什么区别
    CLR Via CSharp读书笔记(16):数组
    ubuntu server 下部署apache+django+mod_wsgi环境
    Ubuuntu10.04上配置Django、Apache、mod_wsgi
    Tutorial: Installing Django 1.1. on CentOS 5.4
  • 原文地址:https://www.cnblogs.com/yymn/p/5121862.html
Copyright © 2011-2022 走看看