如图,为什么u.a和u.b二进制数据不一样呢,他们不应该是相同的内存位置吗?
你这样看不到 u.a , u.b 的二进制数据。
biset 的构造的参数是一个 unsigned long ,所以构造的过程是读出 u.a 的值,把这个值转换为 unsigned long ,用转换的结果构造 bitset 。u.b 类似。用这种方法看不到 u.a, u.b 后面实际的内存的。
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
在你的 u.b = 10000; 之后,你可以看看你的 u.a 的值:
u.a = 1.401e-41#DEN
这是一个极小值。
bitset 的初始构造并不支持 float 类型,编译器帮你把这个值隐式转换成了 long,这个 long 值就是 0,就是你现在的结果