- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我仍然没有找到为什么最低的有符号负数没有等效的有符号正数的原因?为简单起见,我的意思是 3 位二进制数100是-4?但是我们不能有正数 4 的签名格式,因为我们不能。它溢出了。那么我们如何知道二进制补码 1000 是 -4 1000 0000 是 -128 等等?我们没有原始正数
最佳答案
一种思考方式是,带符号的二进制补码格式的工作原理是为每位分配一个 2 的幂,然后翻转最后一个 2 的幂的符号。我们以-4为例,它表示为100,这意味着该值为
-1 x 2^2 + 0 x 2^1 + 0 x 2^0
如果我们想得到这个值的正数,我们必须取反才能得到
1 x 2^2 - 0 x 2^1 - 0 x 2^0
注意这个值等于
1 x 2^2 + 0 x 2^1 + 0 x 2^0
换句话说,这个值的正常二进制表示是 100。但是,我们在这里遇到了麻烦,因为我们使用的是带符号的二进制补码表示,这意味着我们专门保留了 4 的位作为符号少量。因此,当我们尝试将位模式 100 解释为带符号的三位二进制补码值时,它的结果与我们开始时的结果完全相同。位的短缺是这里的痛点。
更一般地,给定 n 位,其中第一个是二进制补码表示中的符号位,尝试计算 -1000...00 将返回相同的值,因为该位需要存储较大的正值具有赋予它的特殊含义。
那么为什么要这样做呢?这样做的原因是如果你只有 n 位,你不能存储值 -2n - 1 到 2n - 1,因为有 2 n + 1 个不同的数字,只有 2^n 个不同的位模式。因此,排除最大的正数可以将所有不同的数字保存在指定的位模式中。
但为什么要降低高值而不是低值呢?这是为了保持与无符号整数的二进制兼容性。在无符号整数中,值 0 到 2n-1 - 1 都使用标准的基二表示法进行编码。因此,为了使无符号整数和有符号整数完全一致,无符号整数被设计为与前 2n - 1 个无符号整数逐位等效,范围从 0 到 2 n - 1 - 1,包括在内。此后,无符号值需要最高有效位来编码数字,但有符号值使用此作为符号位。
希望这对您有所帮助!
关于c++ - 为什么 -INT_MIN = INT_MIN 以带符号的二进制补码表示?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8917233/
我正在尝试将谷歌地图集成到 Xamarin Android。但是,如标题中所写,收到错误。此错误出现在我的 SetContentView (Resource.Layout.Main); 上,如下所示:
在 Delphi 中如何以非文本模式打开二进制文件?类似于 C 函数 fopen(filename,"rb") 最佳答案 有几个选项。 1。使用文件流 var Stream: TFileStrea
我现在正在处理一个问题,如下所示: 有两个数字 x1 和 x2 并且 x2 > x1。 例如 x1 = 5; x2 = 10; 而且我必须在二进制表示中找到 x1 和 x2 之间的总和。 5 = 10
我有这个“程序集”文件(仅包含 directives ) // declare protected region as somewhere within the stack .equiv prot_s
有没有办法在powershell中确定指定的文件是否包含指定的字节数组(在任何位置)? 就像是: fgrep --binary-files=binary "$data" "$filepath" 当然,
我是一名工程师,而不是软件程序员,所以请原谅我的无知。 我编写了一个 Delphi(7SE) 程序,用于从连接到两个数字温度计的 USB 端口读取“真实”数据类型。 我已经完成了该计划的大部分内容。
我有一些代码,例如: u=(float *)calloc(n, sizeof(float)); for(i=1; i
typedef struct pixel_type { unsigned char r; unsigned char g; unsigned char b;
如何判断二进制数是否为负数? 目前我有下面的代码。它可以很好地转换为二进制文件。转换为十进制时,我需要知道最左边的位是否为 1 以判断它是否为负数,但我似乎无法弄清楚该怎么做。 此外,我如何才能让它返
我有一个带有适当重载的 Vect*float 运算符的 vector 类,我正在尝试创建全局/非成员 float*Vect 运算符,如下所示:(注意这是一个经过大量编辑的示例) class Vect
对于使用 C 编程的项目,我们正在尝试将图像转换为二进制数据,反之亦然。我们在网上找到的所有其他解决方案都是用 C++ 或 Java 编写的。这是我们尝试过的方法: 将图像转换为包含二进制数据的文本文
我需要对列表的元素求和,其中包含所有零或一,如果列表中有 1,则结果为 1,否则为 0。 def binary_search(l, low=0,high=-1): if not l: retu
我到处搜索以找到将 float 转换为八进制或二进制的方法。我知道 float.hex 和 float.fromhex。是否有模块可以对八进制/二进制值执行相同的工作? 例如:我有一个 float 1
当我阅读有关 list.h 文件中的 hlist 的 FreeBSD 源代码时,我对这个宏感到困惑: #define hlist_for_each_entry_safe(tp, p, n, head,
我不知道出了什么问题,也不知道为什么会出现此错误。我四处搜索,但我终究无法弄明白。 void print_arb_base(unsigned int n, unsigned int b) {
在任何语言中都可以轻松地将十进制转换为二进制,反之亦然,但我需要一个稍微复杂一点的函数。 给定一个十进制数和一个二进制位,我需要知道二进制位是开还是关(真或假)。 示例: IsBitTrue(30,1
在下面的代码中,我创建了两个文件,一个是文本格式,另一个是二进制格式。文件的图标显示相同。但是这两个文件的特征完全相同,包括大小、字符集(==二进制)和流(八位字节)。为什么没有文本文件?因为如果我明
我想通读一个二进制文件。谷歌搜索“python binary eof”引导我here . 现在,问题: 为什么容器(SO 答案中的 x)不包含单个(当前)字节而是包含一大堆字节?我做错了什么? 如果应
为什么只允许以 10 为基数使用小数点?为什么以下会引发语法错误? 0b1011101.1101 我输入的数字是否有歧义?除了 93.8125 之外,字符串似乎没有其他可能的数字 同样的问题也适用于其
boost 库中有二进制之类的东西吗?例如我想写: binary a; 我很惭愧地承认我曾尝试找到它(Google、Boost)但没有结果。他们提到了一些关于 binary_int<> 的内容,但我既
我是一名优秀的程序员,十分优秀!