C++对于bit的操作 bit直接赋值 及其他技巧(未完)

时间:2022-10-05 13:59:23


最近做一个压缩程序,需要直接操作bit这一单位,但是C和C++这两个号称面向底层的语言竟然没有提供对于bit的直接支持,最小单位是bit。。

后来发现了一个间接操作bit的方法,就是凑成一个int来读或者写,配合上<<和>>和&等来进行操作,这些后面再更

首先是直接利用二进制数给int赋值。

对于16进制赋值就不提了,人所共知的事情。但是毕竟16进制等等还是经历了一层转换,某些时候(比如现在这个时候=-=)实在是麻烦,还得多写一个转换函数,闹心啊。。明明赋值存储进去就是二进制,我们赋值时候却要从二进制转成16进制,赋值后又成了二进制然后进入了计算机中,这不是浪费青春浪费计算机资源么。

当然非要进制转换,其实也不必自己去写个转换函数,可以查一下strtoul()的说明,对string进行任意进制转换

http://blog.csdn.net/czxyhll/article/details/7876084


C语言里头支持直接的二进制赋值,平常都是熟悉的0xA12E等等,类比换成0b0101010就可以了,最简洁明了

 
int a;

a=0b0100101; 

但是C++上头写0b010101就直接提示出错,只得另寻他法。。于是:

利用汇编直接对a进行二进制赋值,简单粗暴有效


int a;

_asm MOV Dword Ptr a, 01111111b

当然赋值不要造成溢出,int在32位VS2010是4Byte,自己注意吧



对于程序里头动态构造二进制数

可以考虑利用+1和移位符号来逐个构建。。实际时候可以利用一个数组和循环来构建

比如10001010B这个二进制数

 a=1;//1B 
 a<<3;//1000B
 a+=1;//1001B
 a<<2;//1000100B
 a+=1;//1000101B 
 a<<1;//10001010B 




相关讨论:

http://*.com/questions/3834336/why-does-c-support-hex-assignment-but-lack-binary-assignment-how-best-to-sto

bytes.com/topic/c/answers/643503-binary-values-assignment


待续