memcpy实现
typedef unsigned int size_t; void * my_memcpy ( void *dest, const void *src, size_t num ) { void* ret = dest; while (num--) { *(char*)dest = *(char*)src; dest = (; src = (; } return ret; } //to solve memory overlap void *my_memcpy(void *dst, const void *src, size_t count) { char *pdst = static_cast<char *>(dst); const char *psrc = static_cast<const char *>(src); if (pdst > psrc && pdst < psrc + count) { ; i >= ; i--) { pdst[i] = psrc[i]; } } else { ; i < count; i++) { pdst[i] = psrc[i]; } } return dst; } C语言中使用#include <string.h>; C++中使用#include <cstring>和#include <string.h>都可以。 .source和destin所指的内存区域可能重叠,但是如果source和destin所指的内存区域重叠,那么这个函数并不能够确保source所在重叠区域在拷贝之前不被覆盖。而使用memmove可以用来处理重叠区域。函数返回指向destin的指针. .如果目标数组destin本身已有数据,执行memcpy()后,将覆盖原有数据(最多覆盖n)。如果要追加数据,则每次执行memcpy后,要将目标数组地址增加到你要追加数据的地址。 注意:source和destin都不一定是数组,任意的可读写的空间均可。 6函数实现 微软中: void*__cdeclmemcpy( void*dst, constvoid*src, size_tcount ) { void*ret=dst; #ifdefined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC) { externvoidRtlMoveMemory(void*,constvoid*,size_tcount); RtlMoveMemory(dst,src,count); } #else/*defined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC)*/ /* *copyfromloweraddressestohigheraddresses */ while(count--){ *(char*)dst=*(char*)src; dst=(; src=(; } #endif/*defined(_M_MRX000)||defined(_M_ALPHA)||defined(_M_PPC)*/ return(ret); } coreutils中: void*memcpy(void*destaddr,voidconst*srcaddr,size_tlen) { char*dest=destaddr; charconst*src=srcaddr; ) { *dest++=*src++; } returndestaddr; } Linux中: void*memcpy(void*dest,constvoid*src,size_tcount) { assert(dest!=NULL&&src!=NULL); char*tmp=dest;constchar*s=src; ;i<count;i++) { tmp[i]=s[i]; } returndest; } 程序例example1 作用:将s中的字符串复制到字符数组d中。 //memcpy.c #include<stdio.h> #include<string.h> intmain() { char*s="GoldenGlobalView"; chard[]; clrscr(); memcpy(d,s,(strlen(s)+)); printf("%s",d); getchar(); return0; } 输出结果:Golden Global View example2 作用:将s中第13个字符开始的4个连续字符复制到d中。(从0开始) #include<string.h> intmain( { char*s="GoldenGlobalView"; chard[]; memcpy(d,s+,);//从第13个字符(V)开始复制,连续复制4个字符(View) d[]='\0';//memcpy(d,s+14*sizeof(char),4*sizeof(char));也可 printf("%s",d); getchar(); return0; } 输出结果: View example3 作用:复制后覆盖原有部分数据 #include<stdio.h> #include<string.h> intmain(void) { charsrc[]="******************************"; chardest[]="abcdefghijlkmnopqrstuvwxyz0123as6"; printf("destinationbeforememcpy:%s\n",dest); memcpy(dest,src,strlen(src)); printf("destinationaftermemcpy:%s\n",dest); return0; } 输出结果: destination before memcpy:abcdefghijlkmnopqrstuvwxyz0123as6 destination after memcpy: ******************************as6 与strcpy函数的区别 strcpy和memcpy主要有以下3方面的区别。 、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。 、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。 、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy
memcpy实现的更多相关文章
- memcpy内存复制
memcpy(predata,frame,1920*1080*4);
- strcpy strlen memcpy等的函数实现
#include <assert.h> #include <string.h> #include <stdlib.h> #include <stdio.h&g ...
- memcpy函数用法
memcpy函数用法 .分类: VC++ VC++ mfc matlab 2011-12-01 19:17 14538人阅读 评论(0) 收藏 举报 null 原型:extern void *memc ...
- memcpy和memmove
memcpy函数 函数原型 void *memcpy(void *dest, const void *src, size_t n); dest:目标地址 src: 起始地址 n: 字节数 头文件 st ...
- strcpy和memcpy的区别(转载)
strcpy和memcpy都是标准C库函数,它们有下面的特点.strcpy提供了字符串的复制.即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符. 已知strcpy函 ...
- strncpy和memcpy的区别
今天不小心在该用memcpy的时候,用了strncpy使自己吃了亏,所以写出这个博文. memcpy就是纯字节拷贝,而strncpy就不同了,字符串是以'\0'结尾的.如果一个字符buffer长度为6 ...
- strcpy vs memcpy
[本文连接] http://www.cnblogs.com/hellogiser/p/strcpy_vs_memcpy.html [分析] strcpy和memcpy都是标准C库函数,它们有下面的特点 ...
- memcpy vs memmove
[本文连接] http://www.cnblogs.com/hellogiser/p/memcpy_vs_memmove.html [分析] memcpy与memmove的目的都是将N个字节的源内存地 ...
- SEH-关于捕获memcpy的异常
网上有说memcpy是C语言写的,没有异常处理机制. 但是貌似SEH可以处理. SEH("Structured Exception Handling"),即结构化异常处理·是(wi ...
- 等号赋值与memcpy的效率问题
转自:http://www.aiuxian.com/article/p-1309055.html 偶尔看到一个说法,说,小内存的拷贝,使用等号直接赋值比memcpy快得多.结合自己搜集到的资料,整理成 ...
随机推荐
- C语言:10个整数排序(别忘了负数)
题目内容: 10个整数排序(别忘了负数) 例如 input 1 0 2 0 3 4 1 9 8 7 output 0 0 1 1 2 3 4 7 8 9 编码: void sort(int *a); ...
- CROC 2016 - Elimination Round (Rated Unofficial Edition) E - Intellectual Inquiry dp
E - Intellectual Inquiry 思路:我自己YY了一个算本质不同子序列的方法, 发现和网上都不一样. 我们从每个点出发向其后面第一个a, b, c, d ...连一条边,那么总的不同 ...
- Django实战(9):实现Product的输入校验
让我们完成上一节中的任务: 1.验证price>0:需要在Form中验证: 2. 验证title唯一:在Model中验证: 3. 验证image_url的扩展名:在Form中验证,还可以顺便在M ...
- vue 父子间组件传值
1.父组件向子组件传值: 实例截图: 实例代码: /*子组件代码*/ //child.vue <template> <div style="border: 1px soli ...
- gp数据库运维
最近需要将一份db2导出的历史数据入库gp集群,然后把每天的增量数据导出成txt文件和对应的log日志,再ftp传输给另外一台机器.其中陆续碰到一些坑,在此记录 历史文件数据清洗 列分隔符的选择 碰到 ...
- mongdb 拓展的下载地址和编译安装(php)
下载地址:https://pecl.php.net/package/mongodb 编译安装: $ tar zxvf mongodb-mongodb-php-driver-<commit_id& ...
- Entity Framework Core介绍(1)
介绍 Entity Framework (EF) Core 是轻量化.可扩展和跨平台版的常用 Entity Framework 数据访问技术. EF Core 可用作对象关系映射程序 (O/RM),以 ...
- leetcode 算法 Excel表列序号 python实现
这道题给我感觉就像一个26进制数一样. A 就是1 B是2 .... Z 是26 如果AB 两位,那就是 1 * 26 + 2 就是A 的数值*26 + B的数值 如果是MNP 三位数 那就 ...
- Mistakes(Updating)
1.当调试时发现无法正常调用函数时,检查是否发生爆栈 对于每个栈仅有4MB的空间,开int只能开大约5*10^5. 大数组一定要开全局变量 2.当long long=int*int时会爆int,一定要 ...
- Android中利用ant进行多渠道循环批量打包
公司负责Android开发的小伙伴学习能力稍微偏弱,交代给他的自动化打包的任务,弄了好久依然没有成效.无奈只好亲自出手. 没有想到过程很顺利,我完全按照如下文章的步骤进行: 主要参考: Android ...