memmove与memcpy
来源:互联网 发布:景甜的神秘力量 知乎 编辑:程序博客网 时间:2024/05/01 13:11
void * __cdecl memcpy ( void * dst,const void * src,size_t count)
{
void * ret = dst;
while (count--) {
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
return(ret);
}
void * __cdecl memmove ( void * dst,const void * src,size_t count)
{
void * ret = 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(ret);
}
从上面可以看出来,当内存区域有重叠的时候memmove是从高往低开始copy的,内存区域没重叠的时候memcpy和memmove实现的是一样的。
举例:
void main(){
char s[]="china";
//s[2] = 'b';
//memmove(s+2,s,3);
memcpy2(s+2,s,3);
cout<<
}
如果是memmove的话,输出就是chchi,因为此时内存区域有重叠了,如果是memcpy的话就是chchc。
注意:第一点:char *s="china"是不正确的,因为这里的"china"是字符串常量,而*s只是指向第一个位置的指针而已,所以根本就无法将字符串常量进行改动,因 此如果char *s="china"执行如上操作报错,而改成char s[]="china"是字符串数组就没问题了。
第二点:在Windows下面执行memcpy竟然跟memmove结果一致。并没有像源码说的,memcpy无法处理内存区域重叠的问题,关于这点初步认为实现机制不同,的确将这个源码拷过去跟我们想象的是一致的。
- memcpy 与 memmove 实现
- memcpy与memmove区别
- memcpy 与 memmove 区别
- memmove与memcpy
- memcpy与memmove区别?
- memcpy与memmove
- memmove 与memcpy
- memcpy与memmove
- memcpy与memmove
- memcpy与memmove
- memmove与memcpy
- memmove与memcpy区别
- memcpy与memmove源码
- memcpy 与 memmove
- memcpy与memmove解析
- memcpy 与 memmove
- memmove与memcpy区别
- memcpy与memmove区别
- 加密与登录界面
- Inno Setup入门(十二)——Pascal脚本(1)
- SerialPort 串口通信
- java 接口interface的使用
- 基于Apache Mina的一个简单应用
- memmove与memcpy
- 杨辉三角的显示
- Inno Setup入门(十一)——完成安装后执行某些程序
- Java关于十进制转换成十六进制、n进制的解决方案
- 打印调用堆栈
- 在Android的Listview中显示多种视图
- Inno Setup入门(十)——操作注册表
- 虽说作业式的论文很难发散思想,但还好吧!
- Inno Setup入门(九)——修改安装过程中的文字显示