zoukankan      html  css  js  c++  java
  • [转]memmove函数

    【FROM MSDN && 百科】

    原型:  void *memmove( void* dest, const void* src, size_tcount );

    #include<string.h>

    由src所指内存区域复制count个字节到dest所指内存区域。

    src和dest所指内存区域可以重叠,但复制后dest内容会被更改。函数返回指向dest的指针

    Copies the values of num bytes from the location pointed by source to the memory block pointed by destination. Copying takes place as if an intermediate buffer were used, allowing the destination and source to overlap.

    memmove的处理措施:

    (1)当源内存的首地址等于目标内存的首地址时,不进行任何拷贝

    (2)当源内存的首地址大于目标内存的首地址时,实行正向拷贝

    (3)当源内存的首地址小于目标内存的首地址时,实行反向拷贝

    //#define FIRST_DEMO  
    //#define SECOND_DEMO  
    #define MYMEMMOVE  
    #ifdef FIRST_DEMO  
    #include <stdio.h>  
    #include <conio.h>  
    #include <string.h>  
    int main(void)  
    {  
        char s[]="Golden Global View";  
        memmove(s,s+7,strlen(s)+1-7);//+1是取'',可以去掉看下结果  
        printf("%s
    ",s);  
        getch();  
        return 0;  
    }  
    #elif defined SECOND_DEMO  
    #include <stdio.h>  
    #include <conio.h>  
    #include <string.h>  
    int main(void)  
    {  
        char str1[7]="aabbcc";  
        printf( "The string: %s
    ", str1 );  
        memcpy(str1+2,str1,4);  
        printf( "New string: %s
    ", str1 );  
        memmove(str1+2,str1,4);  
        printf( "New string: %s
    ", str1 );  
        getch();  
        return 0;  
    }  
    /*output: 
    The string: aabbcc 
    New string: aaaabb 
    New string: aaaaaa 
    */  
    #elif defined MYMEMMOVE  
    #include <stdio.h>  
    #include <conio.h>  
    #include <string.h>  
    #include <assert.h>  
    void *mymemmove(void *dest,const void *src,size_t coount);  
    int main(void)  
    {  
        char str1[7]="aabbcc";  
        mymemmove(str1+2,str1,4);  
        puts(str1);  
        getch();  
        return 0;  
    }  
    void *mymemmove(void *dest,const void *src,size_t count)  
    {  
        char *ret=(char *)dest;  
        char *dest_t=dest;  
        char *src_t=(char *)src;  
        assert( NULL !=src && NULL !=dest);  
          
        if (dest_t<=src_t || dest_t>=src_t+count)  
        {  
            while(count--)  
            {  
                *dest_t++ = *src_t++;  
            }  
        }  
        else  
        {  
            dest_t+=count-1;  
            src_t+=count-1;  
            while(count--)  
            {  
                *dest_t--=*src_t--;  
            }  
        }  
        return ret;  
    }  
    #endif  
    

      

  • 相关阅读:
    一般删除网页数据和jquery下使用Ajax删除数据的区别
    JavaScript 局部刷新
    ASP.net 网站开发知识点总结
    deque
    DHCP协议
    IP分类以及特殊IP
    重载运算符函数及其注意事项
    linux gdb基本概念
    std::vector 源代码
    iterator 的设计原则和traits
  • 原文地址:https://www.cnblogs.com/ransw/p/3953785.html
Copyright © 2011-2022 走看看