C++对于bit的操作 bit直接赋值 及其他技巧(未完)
来源:互联网 发布:数据产品经理面试题目 编辑:程序博客网 时间:2024/06/05 01:31
最近做一个压缩程序,需要直接操作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://stackoverflow.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
待续
- C++对于bit的操作 bit直接赋值 及其他技巧(未完)
- c-bit相关操作
- C/C bit 位操作
- bit操作的问题
- 对于hp 32bit位 和64bit的区别
- 对于hp 32bit位 和64bit的区别
- C/C++ bit 位操作
- C 语言的 bit 和 bit操作 显示数据的 二进制形式
- Bit 操作
- bit操作
- bit 操作
- java中bit操作常用技巧
- java中bit操作常用技巧<二>
- C/C++位域(Bit-fields)操作的问题
- 一种 bit 操作的应用
- bit的c语言命令
- MFC 关于BMP 24bit 和 32bit的操作
- Bit Manipulation - C语言中二进制操作
- CODE 144: Insertion Sort List
- Java学习笔记之字符串(六)
- File输入输出流综合
- Libevhtp
- 利用内存数据库和布隆过滤器写的网络爬虫
- C++对于bit的操作 bit直接赋值 及其他技巧(未完)
- C语言中static的作用
- LeetCode Integer to Roman数字转成罗马数字
- Struts介绍及学习视频
- 混合背包
- 【转载】ubuntu server 命令行下更换软件源
- 遇到的问题-----------perl脚本用handlersocket把数据插入mysql执行时报错lock_tables
- Android下的两个文件系统:proc和sys(二)
- 阅读大型代码库的方法