请教关于位操作

yzsyzx 2005-07-14 09:45:13
现在有一个很大的多维数组,但是里面存放的不是0就是1
所以现在想能不能使用位数组来节省空间
请问如何来实现 数组元素类型可以是Bit类型吗
...全文
145 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
skykeen 2005-07-15
  • 打赏
  • 举报
回复
如下是一个字节的位节构表示方法
struct stBIT
{
unsigned char a0:1;
unsigned char a1:1;
unsigned char a2:1;
unsigned char a3:1;
unsigned char a4:1;
unsigned char a5:1;
unsigned char a6:1;
unsigned char a7:1; /*a0~a7取值只能是0或1*/
};

访问其中某成员:
stBIT bitTest;
bitTest.a0 = 0;

如果sizeof(bitTest)其结果则应1(字节);


struct stBIT_11
{
unsigned char a0:1;
unsigned char a1:1;
unsigned char a2:1;
unsigned char a3:1;

};
stBIT_11占1字节

struct stBIT_12
{
unsigned char a0:1;
unsigned char a1:1;
unsigned char a2:1;
unsigned char a3:1;
unsigned char a4:1;
unsigned char a5:1;
unsigned char a6:1;
unsigned char a7:1; /*a0~a7取值只能是0或1*/

unsigned char a8:1;
unsigned char a9:1;
};
stBIT_12类型占2字节


hasgone 2005-07-14
  • 打赏
  • 举报
回复
BYTE的存储方式是原码吗?
如果是补码储存的话就不是3了
我也不知道是怎么储存的:)
wenkui 2005-07-14
  • 打赏
  • 举报
回复
考虑别的办法吧
不用多维数组
不存那么多 0 和 1 而是用索引 如第23个为1 22个为0 等等
就是反过来思维
alixnuaa 2005-07-14
  • 打赏
  • 举报
回复
是不是可以用位结构体的办法来操作?
Zhymax 2005-07-14
  • 打赏
  • 举报
回复
不行,不过可以用BYTE来存储,每8个数字保存在一个BYTE的8位中;

例如int a[8]={0, 0, 0, 0, 0, 0, 1, 1};
可以保存为BYTE bits = 3;// 00000011
guxingfeiyu 2005-07-14
  • 打赏
  • 举报
回复
数组中的每8个字节合成一个新数组的字节.

16,550

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧