因此,我正在阅读有关Go(由Ivo Balbaert撰写的The Way to Go)的书,其中有一个代码示例:

const hardEight = (1 << 100) >> 97

由于我没有在此计算机上安装Go,因此我决定将其转换为PHP以查看结果(通过http://writecodeonline.com/php/,因为我也未在该计算机上安装PHP):
echo (1 << 100) >> 97;

上面的结果是8 ....是吗?所以我写了决定好的,让我们写一个从0到100的for循环,然后看一下结果:
for($i = 0; $i <= 100; $i++){
    echo $i . ": ";
    echo ($i << 100) >> 97;
    echo "<br>";
}

但是,结果是:
0: 0
1: 8
2: 16
3: 24
4: 32
5: 40
6: 48
7: 56
8: 64
9: 72
10: 80
11: 88
12: 96
13: 104
14: 112
15: 120
16: 128
17: 136
18: 144
19: 152
20: 160
21: 168
22: 176
23: 184
24: 192
25: 200
26: 208
27: 216
28: 224
29: 232
30: 240
31: 248
32: 256
33: 264
34: 272
35: 280
36: 288
37: 296
38: 304
39: 312
40: 320
41: 328
42: 336
43: 344
44: 352
45: 360
46: 368
47: 376
48: 384
49: 392
50: 400
51: 408
52: 416
53: 424
54: 432
55: 440
56: 448
57: 456
58: 464
59: 472
60: 480
61: 488
62: 496
63: 504
64: 512
65: 520
66: 528
67: 536
68: 544
69: 552
70: 560
71: 568
72: 576
73: 584
74: 592
75: 600
76: 608
77: 616
78: 624
79: 632
80: 640
81: 648
82: 656
83: 664
84: 672
85: 680
86: 688
87: 696
88: 704
89: 712
90: 720
91: 728
92: 736
93: 744
94: 752
95: 760
96: 768
97: 776
98: 784
99: 792
100: 800

有人可以向我解释代码段的最新情况吗?我知道它的位移,但是我对位移的理解不够好,无法识别正在发生的事情。谢谢 :)

最佳答案

以1为例(遍历0-100,但所有对象的本金相同)
从括号内的内容开始:

(1 << 100)

将数字1左移100位。这使您得到1,后跟100个零。然后,这个非常大的数字(称为googol)将右移97,这将使您:
1000

这是十进制数字8的二进制表示形式。对于其他数字,它们首先转换为二进制(因此2变为10,3变为11,依此类推),然后进行计算。

10-06 05:26
查看更多