| |
直接举例说明:
如下demo是可以的,能把数组中的元素值都设置成字符1,
#include <stdio.h>
#include <string.h>
int main()
{
char a[5];
memset(a,'1',5);
for(int i = 0;i < 5;i++)
printf("%c\n",a[i]);
return 0;
}
而如下程序想吧数组中的元素值设置成1,却是不可行的
#include <stdio.h>
#include <string.h>
int main()
{
int a[5];
memset(a,1,5);//这里改成memset(a,1,5 *sizeof(int))也是不可以的
for(int i = 0;i < 5;i++)
printf("%d\n",a[i]);
return 0;
}
问题是:
1,第一个程序为什么可以,而第二个不行,
2,不想要用for,或是while循环来初始化int a[5];能做到吗?(有没有一个像memset()这样的函数初始化)
答:
1.因为第一个程序的数组a是字符型的,字符型占据内存大小是1Byte,而memset函数也是以字节为单位进行赋值的,所以你输出没有问题。而 第二个程序a是整型的,使用memset还是按字节赋值,这样赋值完以后,每个数组元素的值实际上是0x01010101即十进制的16843009。你 看看你输出结果是否这样?
2.如果用memset(a,1,20);
就是对a指向的内存的20个字节进行赋值,每个都用ASCII为1的字符去填充,转为二进制后,1就是00000001,占一个字节。一个INT元素是4 字节,合一起就是1000000010000000100000001,就等于16843009,就完成了对一个INT元素的赋值了。
内存初始化函数memset()用法详解
作用:在一段内存中填充某个给定的值,注意填充时是按照字节顺序填充的,而不是按照元素填充。
此方法是对较大的结构体和数组进行清零操作的一种有效方法。
函数形式:memset(void *buffer,int c,size_t n)
buffer是需要设置的内存的开始地址;c是期望填充值;n是需要填充的字节数。
例1:一个int a[10]型变量,则memset(a,100,sizeof(int))此操作后,元素a[0]的每个字节的值都是100,即0x64,二进制表示: 01100100,所以元素a[0]为0x64646464,二进制表示:01100100 01100100 01100100 01100100
void main()
{ int i,a[20];
memset(a,10,5*sizeof(int));
for(i=0;i<20;i++)
cout< 此函数输出的10个元素并非10,而是每个字节都是00001010组成的int型数。
例2:
#include
#include
void main( void )
{
char buffer[] = "This is a test of the memset function";
printf( "Before: %s\n", buffer );
memset( buffer, '*', 4 );
printf( "After: %s\n", buffer );
}
Output
Before: This is a test of the memset function
After: **** is a test of the memset function