memcpy函数

c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。
(可以复制其他任意数据类型)

strcpy(a,b);
只能将b字符串复制给a字符串

函数原型
void *memcpy(void *dest, const void *src, size_t n);

功能
从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。

先讲复制字符串:

#include <iostream>
#include <cstring>
int main()
{
    char *a="123456789";
    char b[20];
    memcpy(b,a,strlen(a)+1);
 //为什么要加一呢,这是因为字符串最后还有一个‘\0’结束符
 //输出是根据读到‘\0’就结束输出的,所以需要把'\0'一起复制过来
    std::cout<<b<<std::endl;
    return 0;
}

这样输出的b=“123456789”;

再看另外一种复制字符串的方式:

#include <iostream>
#include <cstring>
int main()
{
    char *a="123456789";
    char b[20];
    memcpy(b,a+2,6);
 //从a的第二个字符开始复制6个字符,“345678”
    b[6]='\0';//必须有这个,结束符
    std::cout<<b<<std::endl;
    return 0;
}

最后还将一个int型的数组复制:

#include <iostream>
#include <algorithm>
#include <cstring>
int main()
{
    int a[9]={1,2,3,4,5,6,7,8,9};
    int b[20];
    memcpy(b,a,sizeof(int)*9);
    //第三个数为字节,复制a地址开始往后的sizeof(int)*9个字节给b地址开始
    //那个9就是复制的元素个数
    for(int i=0;i<9;i++)
    std::cout<<b[i]<<std::endl;
    return 0;
}

最后:说下strcpy和memcpy的区别:
strcpy和memcpy主要有以下3方面的区别。
1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。
2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符”\0”才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。
3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy

时间: 2024-10-05 06:02:48

memcpy函数的相关文章

提前认识软件开发(8) memset()与memcpy()函数

软件项目中的代码,少则数千行,多则上万行,但并非无规律可循.阅读了那么多代码之后,我发现有两个函数出现的频率很高,那就是memset()与memcpy()函数,它们都是C语言编程中经常要用到的.工作之余,我查了一些资料,现对它们作一个简单的说明. 1. memset()函数 (1)函数原型 void *memset( void *dest, int c, size_t count ). (2)函数作用 在MSDN中,将该函数的作用描述为:Sets buffers to a specified c

让你提前认识软件开发(8):memset()与memcpy()函数

第1部分 重新认识C语言 memset()与memcpy()函数           软件项目中的代码,少则数千行,多则上万行,但并非无规律可循.阅读了那么多代码之后,我发现有两个函数出现的频率很高,那就是memset()与memcpy()函数,它们都是C语言编程中经常要用到的.工作之余,我查了一些资料,现对它们作一个简单的说明.         1. memset()函数         (1)函数原型         void *memset( void *dest, int c, size

在调用memcpy函数时出现 异常: 0xC0000005: 读取位置 0x006bd000 时发生访问冲突

问题描述 在调用memcpy函数时出现 异常: 0xC0000005: 读取位置 0x006bd000 时发生访问冲突 BOOL Kirsch(BYTE *pData,int Width,int Height) {//定义实现Kirsch算法的8个模板: int i,j,s,t,k,max,sum[8]; static int a[3][3]={{+5,+5,+5},{-3,0,-3},{-3,-3,-3}}; static int a1[3][3]={{-3,+5,+5},{-3,0,+5},

JAVA实现C语言中的memcpy函数

问题描述 在得不到首地址的情况下如何更好地用JAVA实现memcpy函数 解决方案 解决方案二:为啥要操作内存呢?你需要实现什么功能呢?如果是拷贝数组,可以在Arrays类里找到封装好的方法.解决方案三:引用1楼oh_Maxy的回复: 为啥要操作内存呢?你需要实现什么功能呢?如果是拷贝数组,可以在Arrays类里找到封装好的方法. 因为我想操作24-bit的bmp格式图片,实现它的旋转,模拟了好了旋转的方法后,我想将旋转的图保存到一个新文件,因为24-bit的位图是一个像素对应3个字节,所以我想

【19】实现strcpy和memcpy函数

一. strcpy函数 1. strcpy的原型是char* strcpy(char *des, const char *src); 返回des指针.     作用是把src指针指向的字符串复制到des指针指向的字符串中. 2. des所指向的内存空间要足够大保证能够容纳src所指的字符串,strcpy函数碰到第一个\0字符的时候结束复制 3. strcpy函数的实现,考虑内存重叠 //strcpy函数实现 char* strcpy(char *des, const char *src){ //

对比C语言中memccpy()函数和memcpy()函数的用法_C 语言

C语言memccpy()函数:复制内存中的内容头文件: #include <string.h> 定义函数: void * memccpy(void *dest, const void * src, int c, size_t n); 函数说明:memccpy()用来拷贝src 所指的内存内容前n 个字节到dest 所指的地址上.与memcpy()不同的是,memccpy()会在复制时检查参数c 是否出现,若是则返回dest 中值为c 的下一个字节地址. 返回值:返回指向dest 中值为c 的下

C函数之memcpy()函数用法

头文件:#include <string.h> memcpy() 用来复制内存,其原型为:    void * memcpy ( void * dest, const void * src, size_t num ); memcpy() 会复制 src 所指的内存内容的前 num 个字节到 dest 所指的内存地址上. memcpy() 并不关心被复制的数据类型,只是逐字节地进行复制,这给函数的使用带来了很大的灵活性,可以面向任何数据类型进行复制. 需要注意的是: dest 指针要分配足够的空

windows常用 API函数

系统API查询 http://www.vbgood.com/api.html http://hi.baidu.com/3582077/item/9cc3483b581f53c5392ffae3 第一个:FindWindow根据窗口类名或窗口标题名来获得窗口的句柄,该函数返回窗口的句柄, 这个函数的定义是这样的 HWND WINAPI FindWindow(LPCSTR lpClassName,LPCSTR lpWindowName);第一个参数填窗口的类名,第二个填窗口的标题名,其实是不需要同时

windows常用API函数

系统API查询 http://www.vbgood.com/api.html http://hi.baidu.com/3582077/item/9cc3483b581f53c5392ffae3 第一个:FindWindow根据窗口类名或窗口标题名来获得窗口的句柄,该函数返回窗口的句柄, 这个函数的定义是这样的 HWND WINAPI FindWindow(LPCSTR lpClassName,LPCSTR lpWindowName);第一个参数填窗口的类名,第二个填窗口的标题名,其实是不需要同时