http://blog.csdn.net/li_ning_/article/details/51418400

下面s和s2指向的内存区域有重叠,memcpy不能正确复制,src赋值给dst时,可能会修改自身的值

char s[] = "abcdefghij";
char *s2 = s + ;
memmove(s2, s, strlen(s2)+);//s2的最后一个未知 为'\0'字符,从s位置开始复制,不能多一个元素覆盖了结尾的‘\0'
cout << s2 << endl;//只复制strlen(s2)个字节,s2输出abcdef,strlen(s2)的值为6
cout << strlen(s2) << endl;//复制strlen(s2)+1个字节,s2结尾不是'\0',strlen(s2)的值为23

s2的位置是第4个,s是第0个,strlen(s2)的长度为efghij占用的内存空间,共五个字节

重叠分两种情况,src的位置在dst指向区域子内,dst位置在src之内;memmove的第三个参数应该不大于dst指向的内存区域长度

void *memmove(void*dst,void*src, size_t num) size_t是无符号整数

dst>src,正向拷贝,memcpy可处理;dst<src,需要反向拷贝,memcpy不能处理这种情况

 struct {
char name[];
int age;
} person, person_copy;
void *Memmove(void*dst, void*src, int size_t)
{
if (dst == NULL || src == NULL) return NULL; //正向逐字节拷贝,反向逐字节拷贝,没有检测要拷贝的字节数超出dst指向的内存区域;dst=src,什么也不做
if (dst < src) {
char *p = (char*)(dst);
char *q = (char*)(src);
while (size_t)
{
*p++ = *q++;
size_t--;
}
}
if (dst > src){
char *p = (char*)(dst)+size_t - ;
char *q = (char*)(src)+size_t - ;
while (size_t)
{
*p-- = *q--;
size_t--; }
} return dst;
} int main()
{
char s[] = "abcdefghij";
char *s2 = s + ;
memmove(s2, s, strlen(s2));//s2的最后一个未知 为'\0'字符,从s位置开始复制,不能多一个元素覆盖了结尾的‘\0'
cout << s2 << endl;//只复制strlen(s2)个字节,s2输出abcdef,strlen(s2)的值为6
cout << strlen(s2) << endl;//复制strlen(s2)+1个字节,s2结尾不是'\0',strlen(s2)的值为23
char *s3 = s + ;
cout << s << endl;
memmove(s3, s2, strlen(s3));
cout << s3 << endl;
cout << s << endl;
return ;
}
//int main()
//{
// int i = 0;
// int arr1[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
// int arr2[10] = { 0 };
// int arr3[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
// cout << sizeof(arr1) << endl;
// Memmove(arr2, arr1, sizeof(arr1));
// Memmove(arr3 + 5, arr3 + 4, 3 * sizeof(int));
// for (i = 0; i < 10; i++)
// {
// printf("%d ", arr2[i]);
// }
// printf("\n");
// for (i = 0; i < 10; i++)
// {
// printf("%d ", arr3[i]);
// }
// system("pause");
// return 0;
//}

memcpy不能复制内存重叠区域,memmove可以拷贝重叠内存的更多相关文章

  1. C语言标准库函数memcpy和memmove的区别以及内存重叠问题处理

    ①memcpy()和memmove()都是C语言中的标准库函数,定义在头文件string.h中,作用是拷贝一定长度的内存的内容,原型分别如下: void *memcpy(void *dst, cons ...

  2. 内存操作函数memmove,memcpy,memset

    通过字符串的学习,我们知道字符串操作函数的操作对象是字符串,并且它的结束标志是结束符\0,当然这个说的是不 受限制的字符串函数.然而当我们想要将一段内存的数据复制到另一块内存时,我们不能使用字符串操作 ...

  3. 【C语言】模拟实现memmove函数(考虑内存重叠)

    //模拟实现memmove函数(考虑内存重叠) #include <stdio.h> #include <assert.h> #include <string.h> ...

  4. JDK1.8-Java虚拟机运行时数据区域和HotSpot虚拟机的内存模型

    目录 介绍 官方文档规定的运行时数据区域 程序计数器 Java虚拟机栈 本地方法栈 虚拟机栈和本地方法栈溢出 Java堆 演示堆内存溢出 方法区 运行时常量池 演示方法区溢出 HotSpot虚拟机的内 ...

  5. 【OpenCV学习】计算两幅图像的重叠区域

    问题描述:已知两幅图像Image1和Image2,计算出两幅图像的重叠区域,并在Image1和Image2标识出重叠区域. 算法思想: 若两幅图像存在重叠区域,则进行图像匹配后,会得到一张完整的全景图 ...

  6. JVM内存各个区域分工简单介绍

    JVM内存各个区域简单介绍: 程序计数器:程序计数器是一块较小的内存空间,它可以看作是当前线程所执行的字节码的行号指示器. 在使用多线程时,为了线程切换后能恢复到正确的执行位置,每条线程都需要有个独立 ...

  7. java内存区域,jvm内存各个区域详解

    一.运行时数据区域 1.如图所示,可分为如下几个区域. 2.程序计数器 程序计数器是一块较小的内存空间,它的作用可以看做是当前线程所执行的字节码的行号指示器.字节码解释器工作时就是通过改变这个计数器的 ...

  8. 转载: Java虚拟机:运行时内存数据区域、对象内存分配与访问

    转载:  https://blog.csdn.net/a745233700/article/details/80291694  (虽然大部分内容都其实是深入理解jvm虚拟机这本书里的,不过整理的很牛逼 ...

  9. 快速串讲——JVM内存的区域划分

    目的 快速定位JVM内存泄漏或者溢出等问题. 面试基础题,加分项. 文章持续更新,微信搜索「万猫学社」第一时间阅读,关注后回复「电子书」,免费获取12本Java必读技术书籍. 程序计数器(Progra ...

随机推荐

  1. LCD应用程序测试

    #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl ...

  2. AtCoder Beginner Contest 133 -D — Rain Flows into Dams

    (https://atcoder.jp/contests/abc133/tasks/abc133_d) 思路:每座山为2Xi,每个坝为Ai.已知Ai,求出2Xi. 根据已知的X1,则可分别求出X2-n ...

  3. Java7/8 中的 HashMap 和 ConcurrentHashMap 全解析 (转)

    阅读前提:本文分析的是源码,所以至少读者要熟悉它们的接口使用,同时,对于并发,读者至少要知道 CAS.ReentrantLock.UNSAFE 操作这几个基本的知识,文中不会对这些知识进行介绍.Jav ...

  4. CentOS7 安装Postgresql 11+ 源码编译安装Postgis-2.5.2

    ####安装Postgresql-11yum install zlib-devel gcc makegroupadd postgresuseradd -g postgres postgrespassw ...

  5. 又一年NOIP后的一波总结

    (昨天正式考完了吧...先写一下现在的感受,出成绩以及后续继续更...) 按照国际惯例,还是先讲一下故事吧. Day(~,0] 大概是跟随者时间的推进,气氛越来越紧张吧. 平时好像大家和往常一样,日常 ...

  6. 微信公众号获取微信token

    微信在公众号和小程序的开发都有开放文档一般看文档开发就行,很简单这里写一个小demo获取微信token,之后根据自己的业务获取信息处理即可 package com.demo.ccx; import o ...

  7. 【改】linux中分区的概念

    1.目录和分区 区别:Linux的分区是物理上的概念,从物理上将存储空间分开:Linux的目录是逻辑上的概念,Linux的目录树实际上是一个分区之间的数据逻辑结构关系,不是物理结构: 联系:一个分区必 ...

  8. 【LeetCode】位运算 bit manipulation(共32题)

    [78]Subsets 给了一个 distinct 的数组,返回它所有的子集. Example: Input: nums = [,,] Output: [ [], [], [], [,,], [,], ...

  9. Promise.race 的原理

    // race的原理 Promise.race = function(values){ return new Promise((resolve,reject)=>{ for(let i = 0 ...

  10. java程序员必知的 8大排序

    Java常用的八种排序算法与代码实现 排序问题一直是程序员工作与面试的重点,今天特意整理研究下与大家共勉!这里列出8种常见的经典排序,基本涵盖了所有的排序算法. 1.直接插入排序 我们经常会到这样一类 ...