C++中的fill函数与memset函数的区别
前言
一般来说,给数组中的每一个元素赋相同的值有两种方法:memset函数和fill函数,下面介绍一下二者的区别。
正文
- memset函数
- 函数在头文件< string.h>中
- memset函数格式: memset(数组名,值,sizeof(数组名))
- 按字节赋值,即对每个字节赋相同的值
- 由于是按字节赋值,故通常只使用memset赋0或-1,而赋值其他数值则使用fill()函数。(0的二进制补码为全0,-1的二进制补码为全1,不容易弄错)
- fill函数
- 函数在头文件< algorithm>中
- fill函数格式: fill(数组名,数组名+数组大小,值)
- fill()可以把数组或容器中的某一段区间赋为某个相同的值。和memset不同,这里的赋值可以是数组类型对应范围中的任意值。
例子
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
using namespace std;
int a[10];
void print(){
for(int i=0;i<10;i++){
printf("%d ",a[i]);
if(i==9)printf("\n");
}
}
int main(){
memset(a,0,sizeof(a));
print();
memset(a,-1,sizeof(a));
print();
memset(a,1,sizeof(a));
print();
fill(a,a+10,1);
print();
vector<int> v;
for(int i=0;i<10;i++){
v.push_back(i);
}
vector<int>::iterator it;
for(it=v.begin();it!=v.end();it++){
printf("%d ",*it);
}
printf("\n");
fill(v.begin(), v.end(), 520326);
for(it=v.begin();it!=v.end();it++){
printf("%d ",*it);
}
return 0;
}
后记
最近天气一直下雨哎,有点让人郁闷,一个人在寝室,唯有一直学习才不会感到孤独。