-
函数介绍
函数原型:void* My_Memset(void* ptr, int value, size_t num)。
函数解释:将 ptr 中当前位置后面的 num 个字节用 value 替换并返回 ptr 。
函数作用:在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法。
文档中的解释如图:
-
函数的模拟实现
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
void* My_Memset(void* ptr, int value, size_t num)
{
assert(ptr != NULL);
char* tmp = (char*)ptr;
while (num--)
{
*tmp = (char)value;
++tmp;
}
return ptr;
}
int main()
{
int arr[10];
int i = 0;
int* ret = (int*)My_Memset(arr, 0, sizeof(arr));
for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
{
printf("%d ", *(ret + i));
}
system("pause");
return 0;
}
-
memset 常见的一些问题
①:memset函数按字节对内存块进行初始化,所以不能用它将 int 数组初始化为0
和-1之外的其他值。根据模拟函数可以看出来,memset 是逐字节进行初始化。举个例子,如果 void* My_Memset(void* ptr, int value, size_t num) value=1,1 在内存中的存储为 00000000 00000000 00000000 00000001,截断后每个字节为 00000001 。又因为是 int 型数组,所以一次访问四个字节即为:00000001 00000001 00000001 00000001 ,转化为十进制为:1+1* 2^ 8 +1* 2 ^16 + 1*2^24=16843009,而不是1;
如果 value = 0,同理转化为十进制为 0;
如果 n = -1, -1 在内存中的存储为 11111111 11111111 11111111 11111111,截断后每个字节为 11111111 。又因为是 int 型数组,所以一次访问四个字节即为:11111111 11111111 11111111 11111111 ,转化为十进制为还是为 -1。
而对字符数组操作时则取后八位赋值给字符数组,其八位值作为ASCII码,因此无论 ch 多大只有后八位二进制有效,而后八位二进制的范围在(0~255)中。
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
void* My_Memset(void* ptr, int value, size_t num)
{
assert(ptr != NULL);
char* tmp = (char*)ptr;
while (num--)
{
*tmp = (char)value;
++tmp;
}
return ptr;
}
int main()
{
char arr[10];
int i = 0;
char* ret = (char*)My_Memset(arr, 97, sizeof(arr));
//或者:char* ret = (char*)My_Memset(arr, ‘a’, sizeof(arr));
//其实也是将字符‘a’ 的 ASCII 传过去
for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
{
printf("%c\n", *(ret + i));
}
system("pause");
return 0;
}//输出 a a a a a a a a a a
- 注意: 在使用该函数时候,不要写反了 value 和 num 的位置.