内存设置函数memset()
void * memset ( void * destination, int n,size_t num );用于初始化所定义的变量
void * memset ( void * destination, int n,size_t num )
{
char *Pdest = (char*)destination;
while(num--)
{
*Pdest++ = n;
}
return destination;
}
内存拷贝函数memcpy() [两种情况内存重叠与不重叠]
void * memcpy ( void * destination, const void * source, size_t num );
- 函数memcpy从source的位置开始向后复制num个字节的数据destination的内存位置
- 这个函数在遇到 '\0' 的时候并不会停下来。
- 如果source和destination有任何的重叠,复制的结果都是未定义的(不确定的)
void* my_memcpy(void* destination, const void* source, size_t num)
{
//检查参数
assert(destination != NULL && source != NULL);
//强制转换与保护参数
char* Pdest = (char*)destination;
const char* Psource = (char*)source;
//第一种情况 Pdest<Psource与 Psource+num <Pdest;
if (Pdest < Psource || ((Psource + num) < Pdest))
{
while (num--)
{
*Pdest++ = *Psource++;
}
}
// 第二种情况,内存重叠
else
{
char* Pdest = (char*)destination + num - 1;
const char* Psource = (char*)source + num - 1;
while (num--)
{
*Pdest-- = *Psource--;
}
}
return destination;
}
内存移动函数memmove()
void * memmove ( void * destination, const void * source, size_t num );
- memmove在处理的源内存块和目标内存是可以重叠的
- 当源空间和目标空间出现重叠时,需要使用memmove函数处理
int main ()
{
char str[] = "memmove can be very useful......";
memmove (str+20,str+15,11);
puts (str);
return 0;
}
内存比较函数memcmp()
int memcmp ( const void * ptr1, const void * ptr2, size_t num )
- 比较从ptr1和ptr2指针开始的num个字节
- 返回值介绍 相等返回0 , 小于返回小于0的数, 大于返回大于0的数
int my_memcompare(const void* dst, const void* src, size_t count)
{
assert(dst != NULL && src != NULL);
const char* Pdst = (char*)dst;
const char* Psrc = (char*)src;
while (count--)
{
int result = (*Pdst++ - *Psrc++);
if (result != 0)
return result;
else if (result == 0)
continue;
}
return 0;
}
标签:字符,const,进阶,void,destination,char,num,内存
From: https://blog.51cto.com/u_16192117/7438811