C++中 fill( ) 和memset()的区别和用法

1.首先是头文件的不同

fill()函数的头文件是#include<algorithm>

memset()函数的头文件是#include<cstring>

2.用法的不同

memset()函数原型是:void *memset(void *s, int ch, size_t n);

    函数功能是:将s所指向的某一块内存中的前n个字节的内容全部设置为ch指定的ASCII值, 第一个值为指定的内存地址,块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作, 其返回值为指向s的指针,它是对较大的结构体或数组进行清零操作的一种最快方法。
 

#include <iostream>
#include<cstring>
using namespace std;

int main()
{
	int a[10] = { 1,2,3,4,5 };
	memset(a, 0, sizeof(a));
	for (int i = 0; i < 10; i++) printf("%d ", a[i]);
	return 0;
}

但是要注意的是,memset是按照一个一个字节给元素初始化为中间的参数ch的。如果ch的值为0,结果是对的,但是 如果是2,就不对了,因为整型是四个字节,将一个整型数按每个字节初始化为00000010 00000010 00000010 00000010= 33686018,这样数组元素的值都变成了33686018。

我做了一下实验将ch的值改为256或者512,结果也能初始化为0,这里虽然ch的类型是int占有4个字节,但是memset函数只会取最后一个字节的数来进行初始化,256为 00000000 0000000 00000001 00000000,取最后一个字节为00000000,那就会表示0。从数组的首地址开始,每个字节都会被初始化为0。 

 所以,在memset使用时要千万小心,在给char(单字节)以外的数组赋值时,只能初始化为0或者-1。

fill()函数: 

1.对一维数组a[n]的赋值,
fill(a,a+n,1)
第一个参数是起始地址
第二个参数是我们需要结束的地方,但不会报告a[n],区间为[a[0],a[n])前闭后开
第三个参数是我们需要的赋值,这个相对memeset()就灵活很多

2.对二维数组a[m][n]的赋值
fill(a[0],a[0]+mn,1)
参数的类型和上面的一样,这里唯一值得注意的是第一个起始地址,因为是二维数组,它的第一个数值的表达是 a[0][0],而它的地址就可以用a[0] 来表示。
 

 

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值