bitset类

谁学逆向工程 2010-03-20 09:50:08
bitset类涉及到高阶位、低阶位。这是什么意思
...全文
111 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
herman~~ 2010-03-21
  • 打赏
  • 举报
回复
不太习惯用bitset进行位操作

主要是消息层面如果没做流化 不太适合用bitset
blackfacewa 2010-03-21
  • 打赏
  • 举报
回复
多看就理解了!
kuillldan 2010-03-21
  • 打赏
  • 举报
回复
建议LZ不要看C++Primer了。先补一下基础吧。
kuillldan 2010-03-21
  • 打赏
  • 举报
回复
void main()
{
string str("110110");
bitset<32> bit(str);//bit[0]==0, bit[1] == 1, bit[2] == 1,bit[3] == 0 ..依次类推
//其中 bit[0] 到bit[31]阶数由低到高
cout<<bit<<endl;//输出从左到右阶数由高到低 分别是00000000000000000000000000110110
}
ypb362148418 2010-03-21
  • 打赏
  • 举报
回复
以0位开始的位串是低阶位(low-order bit),以最高位结束的位串是高阶位(high-order bit)。
举个例子:
string s("1100");
bitset<4> b(s); //低阶位为0,高阶位为1


支持下3楼

bitset<>可以操作任意一位数据
niejimaoo 2010-03-21
  • 打赏
  • 举报
回复
左->右
低->高
昵称很不好取 2010-03-20
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 thefirstz 的回复:]
C/C++ code
以0位开始的位串是低阶位(low-order bit),以最高位结束的位串是高阶位(high-order bit)。
举个例子:
string s("1100");
bitset<32> b(s); //低阶位为0,高阶位为1
[/Quote]
写错了,应该是bitset<4> b(s)
昵称很不好取 2010-03-20
  • 打赏
  • 举报
回复
以0位开始的位串是低阶位(low-order bit),以最高位结束的位串是高阶位(high-order bit)。
举个例子:
string s("1100");
bitset<32> b(s); //低阶位为0,高阶位为1

cy330206 2010-03-20
  • 打赏
  • 举报
回复
就是直接可以用这个类来运算任何位
在C++的STL中实现由一个bitset模板,其用法如下: std::bitset bs; 也就是说,这个bs只能支持64位以内的位存储和操作;bs一旦定义就不能动态增长了。本资源附件中实现了一个动态Bitset,和标准bitset兼容。 /** @defgroup Bitset Bitset位集 * @{ */ //根据std::bitset改写,函数意义和std::bitset保持一致 class CORE_API Bitset: public Serializable { typedef typename uint32_t _Ty; static const int _Bitsperword = (CHAR_BIT * sizeof(_Ty)); _Ty * _Array; //最低位放在[0]位置,每位的默认值为0 int _Bits;//最大有效的Bit个数 private: int calculateWords()const; void tidy(_Ty _Wordval = 0); void trim(); _Ty getWord(size_t _Wpos)const; public: //默认构造 Bitset(); //传入最大的位数,每位默认是0 Bitset(int nBits); virtual ~Bitset(); //直接整数转化成二进制,赋值给Bitset,最高低放在[0]位置 Bitset(unsigned long long _Val); //拷贝构造函数 Bitset(const Bitset & b); Bitset(const char * str); Bitset(const std::string & str, size_t _Pos, size_t _Count); public: size_t size()const; //返回设置为1的位数 size_t count() const; bool subscript(size_t _Pos) const; bool get(size_t pos) const; //设置指定位置为0或1,true表示1,false表示0,如果pos大于数组长度,则自动扩展 void set(size_t _Pos, bool _Val = true); //将位数组转换成整数,最低位放在[0]位置 //例如数组中存放的1011,则返回13,而不是返回11 unsigned long long to_ullong() const; bool test(size_t _Pos) const; bool any() const; bool none() const; bool all() const; std::string to_string() const; public: //直接整数转化成二进制,赋值给Bitset,最高位放在[0]位置 Bitset& operator = (const Bitset& b); //直接整数转化成二进制,赋值给Bitset,最高位放在[0]位置 Bitset& operator = (unsigned long long ull); //返回指定位置的值,如果pos大于位数组长度,自动拓展 bool operator [] (const size_t pos); //测试两个Bitset是否相等 bool operator == (const Bitset & b); bool operator != (const Bitset & b); Bitset operator<>(size_t _Pos) const; bool operator > (const Bitset & c)const; bool operator < (const Bitset & c)const; Bitset& operator &=(const Bitset& _Right); Bitset& operator|=(const Bitset& _Right); Bitset& operator^=(const Bitset& _Right); Bitset& operator<>=(size_t _Pos); public: Bitset& flip(size_t _Pos); Bitset& flip(); //将高位与低位互相,如数组存放的是1011,则本函数执行后为1101 Bitset& reverse(); //返回左边n位,构成新的Bitset Bitset left(size_t n) const; //返回右边n位,构成新的Bitset Bitset right(size_t n) const; //判断b包含的位数组是否是本的位数组的自串,如果是返回开始位置 size_t find (const Bitset & b) const; size_t find(unsigned long long & b) const; size_t find(const char * b) const; size_t find(const std::string & b) const; //判断本的位数组是否是b的前缀 bool is_prefix(unsigned long long & b) const; bool is_prefix(const char * b) const; bool is_prefix(const std::string & b) const; bool is_prefix(const Bitset & b) const; void clear(); void resize(size_t newSize); void reset(const unsigned char * flags, size_t s); void reset(unsigned long long _Val); void reset(const char * _Str); void reset(const std::string & _Str, size_t _Pos, size_t _Count); //左移动n位,返回新的Bitset //extendBits=false "1101" 左移动2位 "0100"; //extendBits=true "1101" 左移动2位 "110100"; Bitset leftShift(size_t n,bool extendBits=false)const; //右移动n位,返回新的Bitset //extendBits=false "1101" 右移动2位 "0011"; //extendBits=true "1101" 右移动2位 "001101"; Bitset rightShift(size_t n, bool extendBits = false) const; public: virtual uint32_t getByteArraySize(); // returns the size of the required byte array. virtual void loadFromByteArray(const unsigned char * data); // load this object using the byte array. virtual void storeToByteArray(unsigned char ** data, uint32_t& length) ; // store this object in the byte array. };

64,664

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

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