zoukankan      html  css  js  c++  java
  • memcpy实现

    typedef unsigned int size_t; 
    void * my_memcpy ( void *dest, const void *src, size_t num ) 
    {    
        void* ret = dest; 
        while (num--) 
        { 
            *(char*)dest = *(char*)src; 
            dest = (char*)dest + 1; 
            src = (char*)src + 1;                 
        } 
        return ret; 
    }
    
    
    //to solve memory overlap
    void *my_memcpy(void *dst, const void *src, size_t count)  
    {  
         char *pdst = static_cast<char *>(dst);  
         const char *psrc = static_cast<const char *>(src);  
           
         if (pdst > psrc && pdst < psrc + count)  
         {  
               for (int i = count - 1; i >= 0; i--)  
               {  
                    pdst[i] = psrc[i];  
               }  
         }   
         else  
         {  
               for (int i = 0; i < count; i++)  
               {  
                    pdst[i] = psrc[i];  
               }  
         }  
         return dst;  
    }   
     
    
    C语言中使用#include <string.h>;
    C++中使用#include <cstring>和#include <string.h>都可以。
    1.source和destin所指的内存区域可能重叠,但是如果source和destin所指的内存区域重叠,那么这个函数并不能够确保source所在重叠区域在拷贝之前不被覆盖。而使用memmove可以用来处理重叠区域。函数返回指向destin的指针.
    2.如果目标数组destin本身已有数据,执行memcpy()后,将覆盖原有数据(最多覆盖n)。如果要追加数据,则每次执行memcpy后,要将目标数组地址增加到你要追加数据的地址。
    注意:source和destin都不一定是数组,任意的可读写的空间均可。
    
    6函数实现
    微软中:
    void*__cdeclmemcpy(
    void*dst,
    constvoid*src,
    size_tcount
    )
    {
    void*ret=dst;
    #ifdefined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC)
    {
    externvoidRtlMoveMemory(void*,constvoid*,size_tcount);
    RtlMoveMemory(dst,src,count);
    }
    #else/*defined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC)*/
    /*
    *copyfromloweraddressestohigheraddresses
    */
    while(count--){
    *(char*)dst=*(char*)src;
    dst=(char*)dst+1;
    src=(char*)src+1;
    }
    #endif/*defined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC)*/
    return(ret);
    }
    coreutils中:
    void*memcpy(void*destaddr,voidconst*srcaddr,size_tlen) { char*dest=destaddr; charconst*src=srcaddr; while(len-->0) { *dest++=*src++; } returndestaddr; }
    Linux中:
    void*memcpy(void*dest,constvoid*src,size_tcount) { assert(dest!=NULL&&src!=NULL); char*tmp=dest;constchar*s=src; for(size_ti=0;i<count;i++) { tmp[i]=s[i]; } returndest; }
    程序例example1 作用:将s中的字符串复制到字符数组d中。
    //memcpy.c #include<stdio.h> #include<string.h> intmain() { char*s="GoldenGlobalView"; chard[20]; clrscr(); memcpy(d,s,(strlen(s)+1)); printf("%s",d); getchar(); return0; } 输出结果:Golden Global View
    example2 作用:将s中第13个字符开始的4个连续字符复制到d中。(从0开始)
    #include<string.h> intmain( { char*s="GoldenGlobalView"; chard[20]; memcpy(d,s+12,4);//从第13个字符(V)开始复制,连续复制4个字符(View) d[4]='';//memcpy(d,s+14*sizeof(char),4*sizeof(char));也可 printf("%s",d); getchar(); return0; } 输出结果: View
    example3 作用:复制后覆盖原有部分数据
    #include<stdio.h> #include<string.h> intmain(void) { charsrc[]="******************************"; chardest[]="abcdefghijlkmnopqrstuvwxyz0123as6"; printf("destinationbeforememcpy:%s ",dest); memcpy(dest,src,strlen(src)); printf("destinationaftermemcpy:%s ",dest); return0; } 输出结果: destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123as6 destination after memcpy: ******************************as6 与strcpy函数的区别 strcpy和memcpy主要有以下3方面的区别。 1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。 2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符""才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。 3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
  • 相关阅读:
    dubbo
    maven
    vue
    SSM框架整合
    MyBatis数据表注解开发
    MyBatis多表操作xml方式
    MyBatis映射配置文件
    Mybatis核心配置文件,传统开发和代理开发(主流)
    SpringMVC高级
    SpringMVC基础
  • 原文地址:https://www.cnblogs.com/timssd/p/4091025.html
Copyright © 2011-2022 走看看