一直想知道 strcpy()、memcpy()、memmove()、memset()的内部实现

strcpy(), 字符串拷贝.


char *strcpy(char *strDest, const char *strSrc)


{


    assert((strDest!=NULL) && (strSrc !=NULL));


    char *address = strDest;    


    while( (*strDest++ = * strSrc++) != '\0')


   NULL ;


    return address ;      


}memcpy, 拷贝不重叠的内存块


void *memcpy(void* pvTo, void* pvFrom, size_t size) //byte是java里的变量类型


{


assert(pvTo != NULL && pvFrom != NULL);


void* pbTo = (byte*)pvTo;


void* pbFrom = (byte*)pvFrom;


/* 内存块重叠吗?如果重叠,就使用memmove */


assert(pbTo>=pbFrom+size || pbFrom>=pbTo+size);


while(size-->0)


   *pbTo++ == *pbFrom++;


return pvTo;


}void *MemCopy(void *dest,const void *src,size_t count)


{


    char *pDest=static_cast<char *>(dest);


    const char *pSrc=static_cast<const char *>(src);


    if( pDest>pSrc && pDest<pSrc+count )


    {


        for(size_t i=count-1; i<=0; ++i)


        {


            pDest[i]=pSrc[i];


        }


    }


    else


    {


        for(size_t i=0; i<count; ++i)


        {


    pDest[i]=pSrc[i];


        }


    }


    return pDest;


}void *Memmove(void *Dst, const void*Src,size_t count)


{


assert(Dst && Src);


void* pDst = Dst;


if (Dst<Src && (char*)Dst > (char*)Src + count)


{


   while(count--)


   {


    *(char*)Dst = *(char*)Src;


    Dst = (char*)Dst + 1;


    Src = (char*)Src + 1;


   }


}


else


{


   Dst = (char*)Dst + count - 1;


   Src = (char*)Src + count - 1;


   while(count--)


   {


    *(char*)Dst = *(char*)Src;


    Dst = (char*)Dst -1 ;


    Src = (char*)Src -1 ;


   }


}


return pDst;


}


void* memmove(void *dest, const void *src,size_t n)


{


    if (n == 0) return 0;


    if (dest == NULL) return 0;


    if (src == NULL)    return 0;


    char *psrc = (char*)src;


    char *pdest = (char*)dest;


    if((dest <= psrc) || (pdest >= psrc + n)) /*检查是否有重叠问题 */


{


   for(int i=0; i < n; i++) /*正向拷贝*/


   {


    *pdest = *psrc;


    psrc++;


    pdest++;


   }


}


else /*反向拷贝*/


{


   psrc += n;


   pdest += n;


   for(int i=0;i<n;i++)


   {


            psrc--;


            pdest--;


            *pdest = *psrc;


   }


}


return dest;


}memset把buffer所指内存区域的前count个字节设置成字符c


void * Memset(void* buffer, int c, int count)


{


char* pvTo=(char*)buffer;


assert(buffer != NULL);


while(count-->0)


   *pvTo++=(char)c;


return buffer;


}

strcpy()、memcpy()、memmove()、memset()的内部实现的更多相关文章

  1. 走进C标准库(7)——"string.h"中函数的实现memcmp,memcpy,memmove,memset

    我的memcmp: int memcmp(void *buf1, void *buf2, unsigned int count){ int reval; while(count && ...

  2. strcpy,memcpy,memmove和内存重叠分析

    一:strcpy函数用法和实现: /* GNU-C中的实现(节选): */ char* strcpy(char *d, const char *s) { char *r=d; while((*d++= ...

  3. strcpy&memcpy&memmove

    strcpy extern char *strcpy(char *dest,char *source); { assert((dest!=NULL)&&(source!=NULL)); ...

  4. strcpy, memcpy, memset函数

    一. strcpy函数 原型声明:char *strcpy(char* dest, const char *src);   头文件:#include <string.h> 和 #inclu ...

  5. 自己实现的库函数2(memset,memcmp,memcpy,memmove)

    memset,memcmp,memcpy,memmove是对内存进行管理的库函数,为了更好的理解和使用这几个函数,自己用C语言实现一下~ //内存设置函数void* my_memset(void* d ...

  6. memset memcmp memcpy memmove 自己实现

    memset memcmp memcpy memmove 自己实现 memset #include <stdio.h> #include <memory.h> #include ...

  7. strcpy, mencpy, memmove三者区别

    首先来看strcpy,目的是实现字符串的复制,这里需要注意几个点: 1.判断指针的有效性 2.将复制后的指针地址返回,为了支持链式操作 3.不要忘记将字符串最后一个自负'\0'复制给dest 4.注意 ...

  8. memcpy/memmove?快速乘?

    memcpy?memmove? //#pragma GCC optimize(2) #include<bits/stdc++.h> using namespace std; ; ],b[n ...

  9. C的memset,memcpy,strcpy 的区别 及memset memcpy memmove源码

    extern void *memcpy(void *dest,void *src,unsigned int count);#include <string.h>   功能:由src所指内存 ...

随机推荐

  1. C++异常处理的编程方法(阿愚,整整29集)

    相遇篇 <第1集 初次与异常处理编程相邂逅> <第2集 C++中异常处理的游戏规则> <第3集 C++中catch(…)如何使用> <第4集 C++的异常处理 ...

  2. 优秀的目录文档内容查找,替换工具,可以飞快的帮助你查询大IIS日志哟。

    这,是一款飞速的目录文档中内容查找的工具. 它,飞快精准的帮助你查询到你想搜索的文档中的内容. 它,是一款由非常牛B,我都不晓得姓名的作者开发的,冒失是C++的windows应用. 你,非常需要他. ...

  3. Oracle数据 行转列

    记录一段行转列SQL代码: select cs.standard_id,cs.area_code,cs.exu_dept, regexp_substr(exu_dept, , level) as de ...

  4. 黑马程序员 Java基础<九>---> 多线程

    ASP.Net+Android+IOS开发..Net培训.期待与您交流! 多线程 一.概述: 1.线程是什么 说到线程,我们就得先说说进程.所谓进程,就是一个正在执行(进行)中的程序,每一个进程执行都 ...

  5. gateone安装(web版本ssh)

    前言: 好久都没来写博客,最近忙啥去了呢? 一是忙于saltstack的二次开发,二是云计算的学习研究中,所以就一直没写东西,今天给大家介绍个工具. 好了,开始正文! 1.首先来说一下为什么要web ...

  6. foreach 和for语句比较

    1.首先想到循环就是执行效率的问题,参考博客http://www.cnblogs.com/yzxchoice/archive/2007/12/15/995949.html 2. 测试时候发现出现“   ...

  7. UVA 1617 Laptop

    题意: 有n条长度为1的线段,确定他们的起点,必须是整数,使得第i条线段在[ri,di]之间.最后输出空隙的最小值 分析: 原始数据排序,排序的规则是先按照右端点排序,右端点相同的情况下,再按照左端点 ...

  8. C# 获取类似java gettime() 的时间格式

    今天做了一个面向Java的接口,需要做到时间的统一,C#提供了System.DateTime.UtcNow 但是需要自己做下处理,记录一下自己的方法, 留着以后查阅方便. /// <summar ...

  9. Ubuntu kylin 有可能成为未来中国的主流系统吗?

    编前语: 无意间开始研究起linux,因为目前互联网很多人,包括我都隐约感觉到,windows系统在中国乃至世界在今后的流行度会逐步降低,不为什么,其中最主要的是安全问题,Microsoft 微软公司 ...

  10. svn 查看某个时间段的记录

    调出svn后,点击查找历史的按钮.