memset_memcpy使用

memset

需要的头文件
在C中
在C++中 


函数介绍
void *memset(void *s, int ch, size_t n);
函数解释:将 s 中前 n 个字节 (typedef unsigned int size_t)用 ch 替换并返回 s 。
memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法[1]。
常见错误
第一: 搞反了 ch 和 n 的位置.
一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20);
而不是 memset(a,20,0);
第二: 过度使用memset,我想这些程序员可能有某种心理阴影,他们惧怕未经初始化的内存,所以他们会写出这样的代码:
char buffer[20];
memset(buffer,0,sizeof(char)*20);
strcpy(buffer,"123");
这里的memset是多余的. 因为这块内存马上就被覆盖了,清零没有意义.
第三: 其实这个错误严格来讲不能算用错memset,但是它经常在使用memset的场合出现
int some_func(struct something *a){


memset(a,0,sizeof(a));

}
这里错误的原因是VC函数传参过程中的指针降级,导致sizeof(a),返回的是一个 something*指针类型大小的的字节数,如果是32位,就是4字节。

memcpy

所需头文件

#include

void *memcpy(void *dest, const void *src, size_t n);

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

函数返回dest的值。

示例:
#include 
#include 

#define BUF1 ("Hello world!")
#define BUF2 ("My name is snail!")

int main()
{
	char str[512];
	memset(str, 0, 512);
	memcpy(str, BUF1, strlen(BUF1));
	
	printf("str = %s\n", str);	
	memcpy(str + strlen(BUF1), BUF2, strlen(BUF2));	
	printf("str = %s\n", str);
	
	return 0;	
}



你可能感兴趣的:(Linux系统相关)