自己实现内存操作函数memset(),memcmp(),memcpy(),memmove()
2016-07-18 08:14
477 查看
1.memset()内存设置函数(初始化)
void *my_memset(void* dest, int c, size_t count)
{
assert(dest != NULL);
char *pdest = (char *)dest;
while (count-->0)
{
*pdest++ = c;
}
return dest;
}
2.memcmp()内存比较函数
int my_memcmp(const char* str1, const char* str2, size_t count)
{
assert(str1 != NULL&&str2 != NULL);
const char *pstr1 = str1;
const char *pstr2 = str2;
int result = 0;
while (count-- > 0)
{
if ((result=*pstr1++-*pstr2++) != '\0')
break;
}
if (result > 0)
result = 1;
else if (result < 0)
result = -1;
return result;
}
3.memcpy()内存拷贝函数
内存拷贝函数是出题率最高的,在实现时需注意内存覆盖的问题
void *my_memcpy(void* dest, const void* src, size_t count)
{
assert(dest != NULL&&src != NULL);
char* pdest =(char*) dest;
const char* psrc =(const char*) src;
if (psrc > pdest || pdest >= psrc + count)
{
while (count--)
*pdest++ = *psrc++;
}
else
{
while (count--)
{
*(pdest + count) = *(psrc + count);
}
}
return dest;
}
4.memmove()内存移动函数
内存移动函数的实现方法完全跟内存拷贝函数实现方法一样,但在使用中还是有细小差别的。但在这里我们就不详细论述他们的差别了。
void *my_memset(void* dest, int c, size_t count)
{
assert(dest != NULL);
char *pdest = (char *)dest;
while (count-->0)
{
*pdest++ = c;
}
return dest;
}
2.memcmp()内存比较函数
int my_memcmp(const char* str1, const char* str2, size_t count)
{
assert(str1 != NULL&&str2 != NULL);
const char *pstr1 = str1;
const char *pstr2 = str2;
int result = 0;
while (count-- > 0)
{
if ((result=*pstr1++-*pstr2++) != '\0')
break;
}
if (result > 0)
result = 1;
else if (result < 0)
result = -1;
return result;
}
3.memcpy()内存拷贝函数
内存拷贝函数是出题率最高的,在实现时需注意内存覆盖的问题
void *my_memcpy(void* dest, const void* src, size_t count)
{
assert(dest != NULL&&src != NULL);
char* pdest =(char*) dest;
const char* psrc =(const char*) src;
if (psrc > pdest || pdest >= psrc + count)
{
while (count--)
*pdest++ = *psrc++;
}
else
{
while (count--)
{
*(pdest + count) = *(psrc + count);
}
}
return dest;
}
4.memmove()内存移动函数
内存移动函数的实现方法完全跟内存拷贝函数实现方法一样,但在使用中还是有细小差别的。但在这里我们就不详细论述他们的差别了。
相关文章推荐
- docker – 你应该知道的10件事
- 解决.NET Core中MailKit无法使用阿里云邮件推送服务的问题
- .NET Core全新路线图
- 月光微博客
- MySQL 数据库性能优化之SQL优化
- delphi 强制退出死循环,要设置label标签
- 百度地图
- 最大公约数与最小公倍数
- Yii框架的session入库
- Wifi小车之 - STM32无线视频篇
- [JZOJ4654]彩色格子
- Linux vmstat命令实战详解
- JZOJ3453. 【NOIP2013中秋节模拟】连通块(connect)
- python学习——图形界面
- php验证码
- 树链剖分+线段树 CF 593D Happy Tree Party(快乐树聚会)
- 自己实现字符串操作函数strlen(),strcat(),strcpy(),strcmp()
- js鼠标事件中的clientX/clientY,screenX/screenY,pageX/pageY,offsetX/offsetY,layerX/layerY,x/y
- etcd相关资料
- Bzoj3531:[Sdoi2014]旅行:树链剖分+动态开点线段树