[CSAPP笔记]Binary , Unsigned , Signed 之间的相互装换
LaTex+MarkDown+Pandoc组合套件写博客的处女作,试试效果。各自的分工为:Latex下编辑公式,在Sublime Text 2下使用Markdown排版,最后用Pandoc导出。
摘要
本文主要讲解 Binary , Unsigned , Signed 三种数据中任意两者之间的转换。下面是文中的一些约定写法。
- 转换名称
- B2Uw(x) : 将位数为w的二进制数 binary 转换为无符号数Unsigned
- B2Tw(x) : 将位数为w的二进制数 binary 转换为补码 Two's complement
- 二进制数的表示 (x) : 用一个向量表示,x = ( x1 , x2 , ... , xw)
1. U2Bw(x)
直接用辗转相除法即可。
2. S2Bw(x)
正数直接装换,然后左边添加0 ; 负数先将其绝对值装换成二进制数,再对低w-1位取反,最高位添加1,用公式表示即为: 下面以三位的三进制数来说明有符数的补码表示
- 3 = 011
- 2 = 010
- 1 = 001
- 0 = 000
- -1 = 111
- -2 = 110
- -3 = 101
- -4 = 100
3. B2Uw(x)
\begin{equation} B2U_w\left( \overrightarrow{x} \right) \doteq \sum_{i=0}^{w-1} x_i 2^i \label{B2U} \end{equation}
4. B2Tw(x)
\begin{equation}B2T_w\left( \overrightarrow{x} \right) \doteq -x_{w-1} 2^{w-1} + \sum_{i=0}^{w-2} x_i 2^i \label{B2T} \end{equation}
5. T2Uw(x)
函数 T2Uw(x) 定义为 T2Uw(x) = T2Bw(B2Uw(x)) 。这个函数输入的是一个 -2(w-1) ~ 2(w-1)-1 之间的数,而输出的无符数也即为该有符数的补码表示。
对于位模式 下的有符二进制数 $\overrightarrow{x}$ ,对比式($\ref{B2U}$) 和式($\ref{B2T}$) , 计算两者之差,我们就可以得到:$ B2U_w\left( \overrightarrow{x} \right) - B2T_w\left( \overrightarrow{x} \right) = x_{w-1} \left( 2^{w-1} - \left( -2^{w-1} \right) \right) = x_{w-1} 2^w $ 。这样就得到了:$B2U_w\left( \overrightarrow{x} \right) = x_{w-1} 2^w + B2T_w\left( \overrightarrow{x} \right)$。若令 $\overrightarrow{x} = T2B_w \left( x \right) $ ,则其反函数为 $ x = B2T_w \left( \overrightarrow{x} \right) $。 由前面三式以及T → B → U变换的传递性,可得:
\begin{equation} B2U_w\left( T2B_w \left( x \right) \right) = T2U_w \left( x \right) = x_{w-1} 2^w + x \label{T2U} \end{equation}
这个关系对于理解“有符数变换得到的无符数也即补码”很有用。
$$ T2U_w \left( x \right)=\left\{
\begin{aligned}
& x+2^w, & x<0,x_{w-1}=1 \\
& x, & x \geq 0,x_{w-1}=0
\end{aligned}
\right.$$
下图说明了 T2U 的转换行为:对于非负数(x ≥ 0), T2U 保留原值 :

图1. 从补码到无符号数的转换。函数
将负数转换为大的正数
6. U2Tw(x)
函数 U2Tw(x) 定义为 U2Tw(x) = B2Tw(U2Bw(x)) 。这个函数输入的是一个 0 ~ 2(w-1)-1 之间的数,输出则为一个 -2w ~ 2(w-1) 之间的数。
上一节我们已经得到,对于负数(x < 0),T2U 被装换为一个大于2w − 1的正数。
反过来,我们再来推导无符号数 u 和与之对应的有符号数 U2Tw(u)之间的关系。 利用上一节的结论, $B2T_w\left( \overrightarrow{u} \right) = B2U_w\left( \overrightarrow{u} \right) - u_{w-1} 2^w$ 。若令 $\overrightarrow{u} = U2B_w \left( u \right)$,则其反函数为 $u = B2U_w \left( \overrightarrow{x} \right)$ 。由前面三式以及 T → B → U 变换的传递性,可得:
\begin{equation}B2T_w\left( U2B_w \left( u \right) \right) = U2T_w \left( u \right) = u - u_{w-1} 2^w \label{U2T} \end{equation}
在 u 原始的无符号表示法中,最高位uw − 1决定了 u 是否大于或等于 2w − 1, 无符数 u 到有符数的装换分段表示为:
$$ U2T_w \left( u \right)=\left\{
\begin{aligned}
& u, & u<2^{w-1},x_{w-1}=0 \\
& u-2^w, & x \leq 0,x_{w-1}=1
\end{aligned}
\right.$$
下图说明了 U2T 转换行为:对于小的数(u < 2w − 1), U2T 保留原值 ; 对于大的数(u ≥ 2w − 1),U2T 被装换为一个负数:

图2.从无符号数到补码的转换。函数U2T 把大于
的数字转换为负值
练习
1.如下函数,在32bit系统中,求问foo(2^31-3)的值是:
int foo(int x) {
return x&-x;
}
A.0 B.1 C.2 D.4
解答:
- (1).运算符号的优先级,减号 '-' 高于异或 '^' 。所以 231-3=2(31-3)=2^28=30
- (2).32位机器中int整型的位数的为 w=32 ,位运算 x 取反,其实为 0xFFFFFFFF-x ,而不是用 232 减去。
- (3).本题中,x=30=0x1E ,依据 T2Uw 可得 -x=0xFFFFE2,所以_x&-x=2_,本题选B
- (4)有么有更简单方法。
y = x & (-x)
That does a bitwise AND between the variable x and its negation, and assigns the result to the variable y. If your system uses two's complement signed arithmetic , then what that manages to get you is the greatest power of 2 that is a factor of x. So, if x is 24, y gets assigned 8, and if x is 12, y gets assigned 4, and if x is 99, y becomes 1. To understand why it does that, you need to understand binary, and two's complement. Look them up on wikipedia.
- 用 15, 16 ,48 三个数验证结论
- x=15=0x0F , -x=-15=232-0x0F=0xFFFFFFF1 , 所以 x&-x=0xF1 & 0x0F = 1 ;
- x=16=0x10 , -x=-16=232-0x10=0xFFFFFF0 , 所以 x&-x=0xF0 & 0x10 = 16
- x=48=0x30 , -x=-48=232-0x30=0xFFFFFD0 , 所以 x&-x=0xD0 & 0x30 = 16
- 总结起来就是, x&-x 得到的是数x的最低一位的非0比特数。
reference
[CSAPP笔记]Binary , Unsigned , Signed 之间的相互装换的更多相关文章
- DOM对象 与 jQuery对象 之间的相互装换
示例代码: //jQuery对象转DOM对象 //因为jQuery对象是一个数组对象,所以转换为DOM对象时要用索引的形式 var $div1 = $("#div1"); //jQ ...
- int和string的相互装换 (c++)
int和string的相互装换 (c++) int转换为string 第一种方法 to_string函数,这是c++11新增的函数 string to_string (int val); string ...
- canvas和图片之间的互相装换
canvas和图片之间的互相装换 一.总结 一句话总结:一个是canvas的drawImage方法,一个是canvas的toDataURL方法 canvas drawImage() Image对象 c ...
- Map 与 JavaBean 的相互装换
目的 为了方便使用 DbUtils,在插入数据时需要传入含有占位符的 SQL 语句和对应占位符的值(数组),封装代码如下: /** * 插入实体 */ public static <T> ...
- xml与java代码相互装换的工具类
这是一个java操作xml文件的工具类,最大的亮点在于能够通过工具类直接生成xml同样层次结构的java代码,也就是说,只要你定义好了xml的模板,就能一键生成java代码.省下了自己再使用工具类写代 ...
- python基础知识-集合,列表,元组间的相互装换
在python中列表,元祖,集合间可以进行相互转化, def main(): set1={'hello','good','banana','zoo','Python','hello'} print(l ...
- 别名现象,java对象之间的相互赋值
请看一下代码 import java.util.*; class book{ static int c = null; } public static void main(String[] args ...
- ios tweak之binary not signed (use ldid -S)问题解决
参考tweak教程写了个简单的tweak,无奈完全无效果,摸索了好长时间才找到方法: 打开terminal ssh root@192.168.1.100 vim /var/log/syslog 找到如 ...
- JAVA和C/C++之间的相互调用。
在一些Android应用的开发中,需要通过JNI和 Android NDK工具实现JAVA和C/C++之间的相互调用. Java Native Interface (JNI)标准是java平台的一部分 ...
随机推荐
- chrome中,BackstopJS 使用cookie文件后依旧提示需要登录
1. 本地环境: apache-tomcat:7.05,jdk8, backstopJS:latest-version 配置tomcat管理用户成功:手工访问tomcat应用内部服务正常: 2. 问 ...
- java quartz
什么是Quartz Quartz是一个完全由Java编写的开源作业调度框架,为在Java应用程序中进行作业调度提供了简单却强大的机制.Quartz允许开发人员根据时间间隔来调度作业.它实现了作业和触 ...
- Win7旗舰版中的IIS配置asp.net 完美通过版,附代码 以及出现的 CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET\Framework64\v2.0.50727\Temporary ASP.NET Files\root\8d57d
先解决问题:“c:\Windows\Microsoft.NET\Framework64\v2.0.50727\Temporary ASP.NET Files\root\8d57d 图: 其他的解决方案 ...
- G - 锘爷考驾照
2017-07-17 11:56:06 writer:pprp 题目描述 大家都知道,锘爷是XDUdp第一人,所以锘爷决定要去考驾照!(这很有逻辑吧),他为了一次考到驾照,于是买了一辆越野车从学校开回 ...
- PAT1071. Speech Patterns (25)
题目要求的Word定义 Here a "word" is defined as a continuous sequence of alphanumerical characters ...
- outline详解
outline这个属性平时用的不太多,最近被问及专门研究一下这个属性的作用. CSS2加进来的outline属性,中文翻译过来是外轮廓. 神马是轮廓? 轮廓,指边缘:物体的外周或图形的外框. 那这样的 ...
- 网络流learning
上次学习网络流还是大一的下学期,之后就被从图论分出来交给队友了 然而吉林一战,队友在深圳读研而不能来,于是需要自己学习一下,争取在比赛前看完网络流建模汇总和一些总结,升华一下. 同时记录一下自己做过的 ...
- Session存储
session其实分为服务器端Session和客户端Session. 当用户首次与Web服务器建立连接的时候,服务器会给用户分发一个sessionid作为标识.用户每次提交页面,浏览器都会把这个ses ...
- linux中的&&和&,|和||
在linux中,&和&&,|和||介绍如下: & 表示任务在后台执行,如要在后台运行redis-server,则有 python a.py & && ...
- .net core mvc部署到IIS导出Word 提示80070005拒绝访问
项目中相信大家经常会遇到导出Word.Excel等需求,在实际开发环境中,一般不会出现什么问题,但当发布到IIS上后可能会遇到各种各样的问题,一般都是权限的问题.前几天把公司项目发布后,出现Word导 ...