memset

前言:

用做题常用的 int 类型说明。

用法:

#include <cstring> 或 #include <string.h>

memset(数组首地址,赋值大小,数组大小)

原理:

总的来说 memset 是以字节赋值的。什么叫做按字节赋值呢?即按一个字节一个字节复制,即其参数中的赋值大小只保留其一个字节(最低位的一个字节)的内容,然后将其赋值赋给参数所指的所指的数组,赋值之后数组中的所有数据的每个字节都为参数中的赋值大小。

上述还不够清楚,下面举例:

#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;

int main()
{
	int tests[10] = {};
	memset(tests,0x7f,sizeof(tests));
  			  //    1
    		  // 0x3f
    		  //0x1ff	
	for(int i = 0;i < 10;i++)
		cout << tests[i] << endl;
	return 0;
}

上面是一个memset的简单示例,首先当给test赋值为 1 时,输出为 16843009。这是因为,1默认是int型,本身有4字节,按之前所说 memset 赋值是按赋值内容的最低位的一个赋值,所以赋值时只留 1 的最低位的一个字节即 00000001。这样数组中的每个字节都变成了00000001,又因为 tests 是 int 型数组,每个元素有 4 个字节,所以执行过 memset 之后,每个数据的 2进制数为 00000001 00000001 00000001 00000001,即 4 个 00000001,即将 00000001 赋值给了每个字节。

当赋值内容为 0x1ff 时,我们发现 0x1ff总共为 9 位bit,即比 1 字节多一位,输出为 -1。这是因为 0x1ff 赋值时只取其最低位的一个字节,即 0xff,即 11111111,8 位都是 1,因为最高位是符号位 1 代表负号,而剩余 7 位为补码表示,所以将其转换为源码就是 -1。

同理当赋值内容是 0x7f,0x3f 时也是如此。

总结:

当使用 memset 时建议使用 0,-1,0x3f 进行赋值。其中 0x3f 可用于将 int 型数组中的元素定义为最大值(即将 0x3f 视为最大值)。为何用 0x3f 而不用 0x7f,我没有多探究,因为大神们都是用 0x3f,首先0x3f 也足够大,并且当自己和自己相加时也不会越界,而 0x7f 则运算过后很容易越界。

安全的赋值大小:0,-1,0x3f(当成无穷大)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Drdajie

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值