strcpy()、memcpy()、memmove()、memset()的内部实现

时间:2023-03-09 06:29:30
strcpy()、memcpy()、memmove()、memset()的内部实现

一直想知道 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;


}