关于实现memcpy和memmove两个库函数的一点体会
来源:互联网 发布:直销矩阵制示意图 编辑:程序博客网 时间:2024/05/21 04:43
最近在论坛上看了一篇关于阿里巴巴面试题的帖子,让自己实现memcpy库函数,要求考虑特殊情况,两段内存存在覆盖,以及指针为空的情况。下面是我对此问题的几点看法(可能还有理解不到的地方)和最终修改的代码。
几点结论:
1,memcpy实现从源source中拷贝n个字节到目标destin中,src源数据应该保留。
2,memmove实现移动一块字节,src源数据可以不保留。
3,memcpy没有考虑内存覆盖问题(由assert条件可知);而memmove考虑了内存覆盖问题,并给出了解决办法。
4,memcpy和memmove中不需要考虑数组越界问题,dst的长度应该大于src的长度,这是调用者应该考虑的问题。
- /*
- * 函数名: memcpy
- * 功 能: 从源source中拷贝n个字节到目标destin中
- * 用 法: void *memcpy(void* destin, const void* source, size_t n);
- * 说 明: 自己实现此库函数
- */
- #include <stdio.h>
- //#include <string.h>//memcpy库函数头文件
- #include <conio.h> //getch头文件
- #include <assert.h> //assert头文件
- typedef unsigned char byte;
- //typedef unsigned int size_t;
- /*
- memcpy自定义函数
- */
- //src要保留
- void* memcpy(void* dst,const void* src,size_t count)
- {
- char* pbTo = (char*)dst;
- char* pbFrom = (char*)src;
- assert(dst!= NULL && src != NULL);//不能存在空指针
- assert(pbTo >= pbFrom+count || pbFrom >= pbTo + count);//防止内存重叠(overlap)
- while (count-- > 0)
- {
- *pbTo++ = *pbFrom++;
- }
- return dst;
- }
- /*
- memmove自定义函数
- */
- //src可以不保留
- void* memmove(void* dst,const void* src,size_t count)
- {
- char* pbTo = (char*)dst;
- char* pbFrom = (char*)src;
- assert(dst != NULL && src != NULL);//不能存在空指针
- if (dst <= src || pbTo >= pbFrom + count)//没有overlap的情况,直接拷贝
- {
- while (count-- > 0)
- {
- *pbTo++ = *pbFrom++;
- }
- }
- else
- {
- pbTo = pbTo + count -1;//overlap的情况,从高位地址向低位拷贝
- pbFrom = pbFrom + count -1;
- while (count-- > 0)
- {
- *pbTo-- = *pbFrom--;
- }
- }
- return dst;
- }
- int main()
- {
- char src[]="*********";
- char dst[]="abcdefghijklmnopqrstuvwxyz";
- char *ptr;
- printf("destination before memcpy: %s/n",dst);
- //测试用例1
- ptr=(char *)memcpy(dst,src,sizeof(src)/sizeof(char));
- //测试用例2
- //ptr=(char *)memmove(dst,src,sizeof(src)/sizeof(char));
- //测试用例3
- //ptr=(char *)memcpy(dst+1,dst,2);//memcpy没有考虑内存覆盖,如果出现覆盖assert报错
- //测试用例4
- //ptr=(char *)memmove(dst+1,dst,2);//memmove考虑了内存覆盖
- if (ptr)
- {
- printf("destination after memcpy: %s/n",ptr);
- }
- else
- {
- printf("memcpy failed/n");
- }
- getch();
- return 0;
- }
修改用例测试:
- /*
- Modification Date: 2010-3-17
- Author: wcdj
- */
- #include <cstdio>
- #include <string.h> // memcpy库函数头文件
- #include <conio.h> // getch头文件
- #include <assert.h> //assert头文件
- typedef unsigned char byte;
- //typedef unsigned int size_t;
- /*
- memcpy自定义函数
- */
- //src要保留
- void* memcpy(void* dst,const void* src,size_t count)
- {
- char* pbTo = (char*)dst;
- char* pbFrom = (char*)src;
- assert(dst!= NULL && src != NULL);//不能存在空指针
- assert(pbTo >= pbFrom+count || pbFrom >= pbTo + count);//防止内存重叠(overlap)
- while (count-- > 0)
- {
- *pbTo++ = *pbFrom++;
- }
- return dst;
- }
- /*
- memmove自定义函数
- */
- //src可以不保留
- void* memmove(void* dst,const void* src,size_t count)
- {
- char* pbTo = (char*)dst;
- char* pbFrom = (char*)src;
- assert(dst != NULL && src != NULL);//不能存在空指针
- if (dst <= src || pbTo >= pbFrom + count)//没有overlap的情况,直接拷贝
- {
- while (count-- > 0)
- {
- *pbTo++ = *pbFrom++;
- }
- }
- else
- {
- pbTo = pbTo + count -1;//overlap的情况,从高位地址向低位拷贝
- pbFrom = pbFrom + count -1;
- while (count-- > 0)
- {
- *pbTo-- = *pbFrom--;
- }
- }
- return dst;
- }
- int main()
- {
- // test
- char src[]="123456";
- char dst[]="abcdefghijklmnopqrstuvwxyz";
- char *ptr;
- printf("destination before memcpy: %s/n",dst);
- //测试用例1
- ptr=(char *)memcpy(dst,src,sizeof(src)/sizeof(char));// "123456"
- //ptr=(char *)memcpy(dst,src,strlen(src));// "123456ghijklmnopqrstuvwxyz"
- //测试用例2
- //ptr=(char *)memmove(dst,src,sizeof(src)/sizeof(char));// "123456"
- //ptr=(char *)memmove(dst,src,strlen(src));// "123456ghijklmnopqrstuvwxyz"
- //测试用例3
- //ptr=(char *)memcpy(dst+1,dst,2);//memcpy没有考虑内存覆盖,如果出现覆盖assert报错
- //测试用例4
- //ptr=(char *)memmove(dst+1,dst,2);//memmove考虑了内存覆盖 "abde...z"
- if (ptr)
- {
- printf("destination after memcpy: %s/n",ptr);
- }
- else
- {
- printf("memcpy failed/n");
- }
- getch();
- return 0;
- }
0 0
- 关于实现memcpy和memmove两个库函数的一点体会
- 关于实现memcpy和memmove两个库函数的一点体会
- 实现memcpy和memmove两个库函数的自学体会 -10-13
- 关于memcpy和memmove的一点说明
- 库函数memcpy()与memmove()实现
- 库函数memcpy()与memmove()实现
- memcpy和memmove的实现
- 模拟实现C库函数:strchr、strcmp、strstr、memcpy和memmove
- 字符串库函数strcpy strcmp strstr memcpy memmove等的实现
- 自己实现的库函数(memset,memcmp,memcpy,memmove)
- memcpy 和 memmove 实现
- memmove、memcpy的实现
- memcpy和memmove的区别与实现
- memcpy和memmove函数的实现
- memcpy和memmove函数的实现
- 【转】memcpy 和memmove的实现
- memcpy和memmove的区别与实现
- memcpy和memmove的区别与实现
- 安装numpy、nltk问题汇总
- wpf中datagrid 控件 隐藏表头方法
- xml功能数据格式
- 黑马程序员——java.lang.Runtime
- 函数
- 关于实现memcpy和memmove两个库函数的一点体会
- 【瞎搞】HDU 4961 Boring Sum
- Shell脚本调试技术
- 黑马程序员——集合工具类
- 使用highChart做报表统计
- ubuntu 14.04 install ibus
- life is tough!最可怕的是牛人还那么努力!
- 第十章 构建基本脚本
- Apache与Nginx的优缺点比较