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] 来表示。
cai小白: 在有符号数的情况下,需要将补码运算结果在转化成反码,而无符号数运算的情况下,结果是默认为源码形式,不需要转化的,所以博主说的没错。
瞳有万千星辰: 他这应该是放到寄存器的环境下说的了,计算机内部数是用补码表示的
FLUENTYAN: 了解一下补码
meiqianqion: 有符号数是按补码解释的
fzc721216: 照你这么说有符号0-1也是65535了?