第二章(1)

大端与小端

将物理内存构造成一个字节数组,叫虚拟内存,其中每个字节都有一个序号,叫地址,所有地址的集合叫虚拟地址空间。CPU的位数,决定了寻址能力。比如32位的CPU,只能访问到地址为0-(2^32-1)的内存单元,所以32位的机器只能有4G内存大小。
一个int类型的整数,在内存中通常表示为4个字节,所以需要4个连续的内存单元去存储。这时候就涉及到了存储顺序的问题。是将低权重的字节放在低地址空间还是高地址空间。将低权重的字节放在低地址空间的模式成为小端。将高权重放低地址的称为大端。
int a = 0x12345678;
现在将a地址开始的四个字节依次读出,如果是小端模式,则读出结果为:0x78 0x56 0x34 0x12。
如果是大端模式,则结果为:0x12 0x32 0x56 0x78

左移右移

  • 左移操作:将bit位向左移动k位,丢弃高位,低位用0补齐。
  • 右移操作:分为算数右移和逻辑右移。
  • 逻辑右移是将高位用0补齐。
  • 算术右移是将高位用最高位的数补齐。如二进制串 10001010 右移2位,算术右移结果为:11100010。因为最高位为1,所以用1补齐。如果最高位是0,则用0补齐。这种方式对有符号数特别重要。
  • Java中,x>>k是算术右移。x>>>k是逻辑右移。

整数的表示

  • 无符号整数:字节的每一位都作为整数数值的一部分。
  • 有符号整数:用补码编码。最高位的权重是-1,例如1001,表示-1x2^3 + 1 = -7。
  • 假如k位有符号整数,则取值范围为:最高位为1,其他位为0,此为最小值。最高位为0,其他位全为1,表示最大值。
  • 即 [-2^(k-1), 2^(k-1) -1]。如4位的范围为:[-8,7]
  • 在C语言中,将有符号整数转化成无符号整数的时候,如果长度允许,各个位都将保留,所以一个负数最后会变成一个很大正数。

整数的加法

  • 无符号整数加法:直接相加,丢掉溢出位。w位二进制数,加法相当于 (a+b)%2^w
  • 有符号整数(补码)加法:形式上和无符号整数加法一样。相加结果正溢出,可以表示为(a+b)-2w。结果负溢出,可以表示为(a+b)+2w。
  • 判断正溢出:a>0,b>0,结果s<=0。
  • 判断负溢出:a<0,b<0,结果s>=0。
  • 补码的非,x大于最小值的时候,非即-x。如果x是最小值,则非是x。因为x+x = -2^(w-1) + -2^(w-1) = -2w,导致负溢出,x+x=-2w + 2^w=0。所以最小值是自己的加法的逆。

整数的乘法

  • 无符号整数乘法:(a*b)%2^w。即取结果的后w为,溢出的位直接丢弃。
  • 有符号整数(补码)乘法:先当做无符号整数相乘,再将结果转成有符号整数即可。即两种乘法的位级表示是一样的,只是最高位的权重相反。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,529评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,015评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,409评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,385评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,387评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,466评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,880评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,528评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,727评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,528评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,602评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,302评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,873评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,890评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,132评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,777评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,310评论 2 342

推荐阅读更多精彩内容