<cstring>是c++对c中的<string.h>进行了重写,这两个头文件中的函数用法是一样的,所以在用的时候包含哪个头文件都行。下面介绍一下
<cstring>头文件里常用的两个函数;分别是memset和memcpy。
1. memset(void* buffer,int a,size_t n);将buffer当前所指位置后面的n个字节填充为a,注意memset是按字节对内存块进行填充的,所以只能
填充0或-1。buffer是一个指针或者数组名,a是int型数据,特别注意a只能是0或-1,n是内存的大小,即字节数。一般用memset()来初始化数组,
效率是比较高的,初始化后可以防止出现“野值”。例如现在有这样一个数组:int a[10];要用0对数组a进行填充,方法为:memset(a, 0, 10*sizeof(int)),
注意第三个参数了,不要搞错。
另外再说一下,当buffer是静态的时候,即buffer是数组的话,第三个参数还可以写成:sizeof(buffer),因为此时buffer是一个数组,有确定的内存大小,
所以在按照字节填充的时候是没有问题的;但是如果bufffer如果是动态的话,即buffer是一个指针,第三个参数就不能像:sizeof(buffer)这样写了,只能
老老实实的写成这个样子:10*sizeof(int)。下面是我在<string.h>头文件中找到的memset()函数的原型:
2. memcpy(a, b, size_t n);把b当前所指位置之后的n个字节中的数据复制到数组a,和上面的memset()差不多,虽然它们的功能不同,但都是按照字节进行操作的。
例如有两个数组:int a[5]={1,2,3,4,5},b[4]={6,7,8,9};现在要把a中的元素复制到b中:memcpy(b, a, 4*sizeof(int)),由于b的长度是4(即20个字节),所以只能把a当前
所指位置之后的20个字节的数据复制到b中,否则会越界。
还有一点要说一下,memcpy()还可以实现把一个数组中的元素复制到一个vector容器中,此时第一个参数为容器,但不能是容器名,第二个参数是数
组名;用这样的形式:memcpy((int*) &a[0], b, size_t n);其中&a[0]代表容器a的首元素地址,而(int*)是memcpy()函数要求的。另外补充一下,数组名即
是首地址,但容器名则不是,所以要把数组中的数据拷贝到容器中,第一个参数不能是容器名,注意区分数组名和容器名。(此种方法慎用,推荐使用下面这个方法)
此外,要实现把一个数组拷贝到容器中,还有一个方法(推荐使用):
int a[5]={1,2,3,4,5};
vector<int> v(a,a+5);
即在声明容器的时候可以直接指定复制,非常方便。下面附上两个函数的使用代码及结果
1 #include<iostream> 2 #include<vector> 3 #include<cstring> 4 using namespace std; 5 int main() 6 { 7 int a[5]={1,2,3,4,5}; 8 int b[4]={4,3,2,1}; 9 10 cout<<"把数组a复制到数组b中后,b中元素为:"; 11 memcpy(b,a+1,4*sizeof(int)); //从a+1开始,把数组a复制到数组b中,复制20个字节的数据 12 for(int i=0;i<4;i++) //a和b所指位置是可以修改的,即a的复制区间是可以改变的,存放到b中的起始位置也是可以改变的 13 cout<<b[i]<<" "; 14 15 vector<int> v1(a,a+5); //必须先初始化v1,并且v1的长度不小于a的长度,否则复制的时候会越界 16 cout<<" 把数组a复制到容器v1中后,v1中元素为:"; 17 for(int i=0;i<v1.size();i++) 18 cout<<v1[i]<<" "; 19 20 memset(a,0,5*sizeof(int)); //分别用0和-1填充数组a 21 cout<<" 用0填充数组a:"; 22 for(int i=0;i<5;i++) 23 cout<<a[i]<<" "; 24 cout<<" 用-1填充数组a:"; 25 memset(a,-1,5*sizeof(int)); 26 for(int i=0;i<5;i++) 27 cout<<a[i]<<" "; 28 cout<<" 用1填充数组b:"; 29 memset(b,1,4*sizeof(int)); //用0和-1以外的数填充会产生非法值 30 for(int i=0;i<4;i++) 31 cout<<b[i]<<" "; 32 cout<<" "; 33 return 0; 34 }
2020-04-25 21:47:02