Bitarray——节省内存的位数组简介

文章介绍了位数组的概念,如何使用C++定义和操作位数组来节省内存。通过BITMASK、BITSET、BITCLEAR、BITTEST等宏定义,实现了位数组的设置、清除和检查功能,特别是在处理大量bool变量时能有效减少内存消耗。例如,一个需要192个bool变量的情况,可以使用位数组用24字节代替。

Bitarray——节省内存的位数组简介

在计算机原理中,1Byte=8bit,但由于内存的对齐方式,实际开发中单个bit或bool变量会占用1字节或更多内存,同理bool[]型变量则会浪费更多内存。因此本文介绍了一种位数组的应用。

定义

#include <limits.h>
//#define CHAR_BIT 8	//未声明limits.h可使用该定义
#define BITMASK(b) (1 << ((b) % CHAR_BIT))					//计算字节内索引
#define BITSLOT(b) (
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值