位集和有符号值

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位位置初始化为对应的值中的比特值。MN和无符号长-长。如果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的构造函数。

所以,当你传递一个整数时,它首先被转换为无符号。结果是,转换后的值将是一个正值,与无符号类型的最大值的有符号值相同。