位集和有符号值
Bitset and signed values
本文关键字:符号 更新时间:2023-10-16
我使用std::bitset
将十进制值转换为二进制表示,但我不确定bitset
是否处理有符号值。
例如,bitset<10>(5)
为0000000101
。但如果是bitset<10>(-5)
呢?
这是我的具体代码:
while (getline(ss, token, ',')){
ss.ignore();
myString.push_back(token);
}
myString[0].erase(0, 1);
myString[1].erase(0, 1);
rt = bitset<7>(stoi(myString[0])).to_string();
ra = bitset<7>(stoi(myString[1])).to_string();
i10 = bitset<10>(stoi(myString[2])).to_string();
并且应当对CCD_ 6进行签名。我当前的代码会处理签名值吗?myString将保存用户输入的十进制表示,但我需要进行一些串联和写入文件,以便轻松转换为字符串。
bitset
本身不处理签名ness。您正在调用的构造函数采用一个unsigned
整数。来自[bitset.cons]:
constexpr bitset(unsigned long long val) noexcept;
效果:构造类
bitset<N>
的对象,将第一个M
位位置初始化为对应的值中的比特值。M
是N
和无符号长-长。如果M < N
,则剩余的比特位置被初始化为零。
所以,如果你用-5
来调用它,它就会被转换为unsigned long long
作为0xfffffffffffffffb
。其中最底层的10位是0x3fb
,这就是您得到的集合。但它没有签名。两个转换函数都会返回一个无符号值(来自[bitset.members]):
unsigned long to_ulong() const;
unsigned long long to_ullong() const;
也就是说,bitset
是一组比特。它没有标志。第一点并不特别——它只是另一点。
Bitset将返回二进制表示。由于负数是使用二的补码存储的,因此您将获得它们在二补码中的表示。例如:
cout << bitset<12>(-5).to_string();
// Prints 111111111011
看看std::bitset
的构造函数。正如您将发现的,它没有接受带符号整数的构造函数。唯一的积分构造函数是接受unsigned long
的构造函数。
所以,当你传递一个整数时,它首先被转换为无符号。结果是,转换后的值将是一个正值,与无符号类型的最大值的有符号值相同。
相关文章:
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- 将无符号char*转换为std::istream*C++
- 如何在C++中将一个无符号的 int 转换为两个无符号的短裤?
- vscode g++链路故障:体系结构x86_64的未定义符号
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- 使用gcc从静态链接的文件中查找可选符号
- C++中无符号字符溢出
- 使用无符号字符数组有效存储内存
- C++:Application.cpp中抛出了未解析的外部符号(解决方案在问题的末尾,供未来的读者参考)
- VC++本机单元测试,找不到调试符号
- 为什么我必须在C++中添加一个赋值符号来声明一个数组
- 检查TCHAR数组输入是否为带符号整数C++
- 用符号版本替换对函数的所有调用
- 未解析的外部符号_MsiLocateComponentW@12.
- 如何打印boost多精度128位无符号整数
- C++模板函数,用于比较任何无符号整数和有符号整数
- 在 Mac 上使用 CMAKE 将 FFTW 和 FFTWPP 链接到项目中时未定义的符号