位集和有符号值

时间:2016-05-02 17:44:26

标签: c++ binary signed bitset

我使用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();

并且i10应该签名。我当前的代码会处理签名值吗? myString将保存用户输入的十进制表示,但我需要连接并写入文件,以便轻松转换为字符串。

3 个答案:

答案 0 :(得分:2)

bitset本身并不处理签名问题。您正在调用的构造函数采用unsigned整数。来自[bitset.cons]:

constexpr bitset(unsigned long long val) noexcept;
     

效果:构造一个类bitset<N>的对象,将第一个M位位置初始化为相应的   val中的位值。 MN中的较小者和值表示(3.9)中的位数   unsigned long long。如果M < N,则剩余的位位置初始化为零。

因此,如果您使用-5进行调用,则会将unsigned long long转换为0xfffffffffffffffb。最后10位是0x3fb,这是你得到的集合。但它没有签名。两个转换函数都会返回一个无符号值(来自[bitset.members]):

unsigned long to_ulong() const;
unsigned long long to_ullong() const;

所有这些都是 - bitset是一组位。它没有迹象。第一位并不特别 - 它只是另一位。

答案 1 :(得分:1)

Bitset将返回二进制表示。由于负数是使用二进制补码存储的,因此您将在二进制补码中得到它们的表示。例如:

cout << bitset<12>(-5).to_string();
// Prints 111111111011

答案 2 :(得分:0)

看一下std::bitset的构造函数。正如您将发现的那样,它没有构造函数接受有符号整数。唯一的构造函数是接受unsigned long的构造函数。

因此,当您传递一个整数时,它首先被转换为unsigned。发生的情况是,转换后的值将是一个正值,与带符号的值相同,是无符号类型的最大值。