我除了投三分,就什么都没有了⋯⋯ 收藏本站
登陆 / 注册 搜索

阅读: 14.1K   回复: 5

[# 系统基础] 一名黑客要理解的计算机核心概念

推荐 [复制链接]
仗剑天涯论坛大牛 2018-2-17 19:34 |显示全部楼层

今生相逢便是缘分,何苦去怨恨,何苦去仇视。

主题破百
    计算机学科中有很多概念, 例如编码(原码,补码,反码), 虚拟内存, 文件, IO,  编译,链接,分组交换,关系, 事务,范式, Hash, 加密。。。等等,本文试图讲一下最重要的核心集合,从这个集合当中就可以变换出计算机编程的各种魔法。
; \2 o. `! a" w0 {4 h7 @% `5 Z9 P: _& Q; O6 f9 p& J' X
    一、冯·诺依曼结构计算机的原理

, e' S$ Z0 Y7 i6 M  `& W# x
/ g2 K( }' j% f1 I0 ^: g* {    所有的计算机语言,不管是Java, Python, Go, C, C++, PHP...... , 无论你在TIOBE上是排行第一还是排行第100,  无论看起来多么花哨,功能多么强大,用起来多么舒服, 最终都要变成基本的二进制指令,老老实实地在冯·诺依曼结构计算机上按规矩执行。
. f. k& ]# p: `: |, Q4 `' {; I
+ J9 j! {4 i6 P; P2 d    这里是根, 我们看到的、用到的都是这棵树上的花和枝叶。
3 p% [% i2 [! ^. v. M- u) t" ~2 Y* \1 z2 \# }4 W3 h; f
    作为志向远大的、有着强烈好奇心的年轻人, 难道你不想到根部来看一看?#j324:
% s: ^- u. g9 ]6 d5 i8 Q8 `
+ \  `/ J+ R# q5 o9 R* K' J9 T    作为最基本的要求, 必须要了解CPU和内存这俩哥们是怎么亲密无间工作的: CPU从内存取出指令,进行译码和执行,执行时从内存中取出数据放到寄存器中, 进行计算, 然后把结果写回到内存。如果是跳转指令, CPU则取出跳转目的地的指令继续执行。
! I/ Y/ R7 T9 n: ?5 d2 V/ U8 [% O
4 c- B+ x* |7 |9 J9 ]    如此简单的过程,竟然组成了多姿多彩的电脑世界: 你可以听音乐,玩游戏、上网聊天、用Word来写文档.....  当然看起来微不足道的一个操作,进入到CPU和内存中都可能需要成千上万条指令来完成。
0 l  {  F, M3 N9 i2 t3 X( |/ m& K/ \) d& a1 ]: w: M5 y8 \5 G9 f5 d
    这些基本的指令组成了顺序、循环、分支等基本的程序结构,形成了更为强大的编程语言的基础。5 W& o+ P$ `! ]' G8 y
. t9 L% f0 h1 Z: @
    CPU和内存、硬盘等设备的速度不匹配,是冯·诺依曼结构计算机的一个核心问题,为了解决这个问题,科学家们绞尽脑汁,想尽了办法, 又引出了一堆概念: 缓存,DMA, 同步,异步,阻塞....2 Y, e) U3 z/ ^4 m
7 f, Y: E7 W* ~( z* w
    书籍:《编码》 《穿越计算机的迷雾》) |- [2 h6 l2 N' X( A, R6 \( j
+ p! s- c* _+ ~: b1 L
    二、进程和线程

4 w$ Q% l( r) q* _- ]! n+ D4 t1 v- u# v5 h$ |
    这俩家伙的重要性不言而喻,因为你写的所有的程序要么会成为一个独立的进程去执行,要么是被一个进程中的线程收编,没有例外 。) a7 A$ ~" ~  J+ s' E# }" K+ l+ J7 G

3 b. x8 g; O& ^7 R$ R    几乎所有的编程语言都会涉及到对多进程或者多线程编程的支持, 特别是多线程的并发编程, 所以你必须得搞明白它的本质是什么。
7 m. g3 z& n* }2 \2 `
# t0 O8 G" @+ Y$ i9 ~    进程是对一个运行中的程序的抽象,没有这个概念,我们是无法实现一边听歌、一边上网的惬意生活。9 `" H; O$ l+ b. c

  p, h8 v" K% Y! P, V- r- w1 T/ Y, _    对于CPU来讲, 它只是“浑浑噩噩”地从某个地方取指令,译码执行,但是它不会意识到在某一刻整个世界已经变了天, 它执行的程序已经发生了切换,另外一个程序(准确地讲叫进程)已经成功地抢班夺权。
; O$ T3 j% s' b% j( U3 O. o9 @4 J4 q: z# B
    每个进程都有一个被操作系统老大维护的进程控制块, 里边保存了这个进程在运行时的重要信息,是进程能来回切换的重要保证。2 d1 E) K, X6 R+ K

: ~' Q) n8 G* n+ t$ S& @    而线程则寄居于进程之内 , 共享进程提供福利(代码和数据)的同时, 还拥有自己的一亩三分地。9 |) }: l3 r0 X% t8 Q; y
, Z. N9 {1 i& z. c5 [
一名黑客要理解的计算机核心概念 1-进程.png

3 d( v  U3 h: s  x% z' p; C    线程的出现,提升了系统的性能、吞吐量和响应性。  但是多进程/多线程编程也带来了一系列问题: 同步,通信,锁, 死锁。。。
. n' D* F* t% M. v9 }6 `2 f* S( Z; Y4 x, v
    扩展阅读:9 d2 ?) M- d) p3 r; z9 d
    《我是一个进程' u% I/ e- J- X' S4 Z2 b
    《我是一个线程
; Z- ]3 M; J3 z* k% ^9 o    书籍:《操作系统概念》
3 }, t- T/ P# d: ]4 @, Z   
9 }8 K( Z- O& J* P) h# O    三、虚拟内存
+ @" \6 Q: x3 t6 T, v  @) d8 a5 g) ~0 F0 b5 i
    有了物理内存, 为啥还有虚拟内存?一个重要的原因就是给各位进程先生提供一个由虚拟地址组成的独立王国,给他们造成一种假象:我最重要,我是独占内存的!; ~+ a! g3 y% Y8 H
! E, @- g" |3 M, t
    每个人在自己的独立王国里闹腾,就不会互相打架, 治安也就有了保证。
) {+ W0 z  K3 F4 f7 v
; B3 g: L6 W& n, p" b2 f! v    但是在虚拟地址王国里做不了什么事情,指令必须在物理内存中才能被执行,操作系统老大用尽浑身解数,把每个进程的虚拟地址映射到实际地址上去,表面上不动声色,背后绝对惊心动魄,分段,分页,页表,还要动用CPU的TLB来加速。
" f: O- q! j5 `# o9 S6 T  G, w- w7 f9 c: u, ^- b" U+ i
    程序并不是像你想象的那样,一下子全部装载到内存的, 而是慢慢地, 用到的时候才进行装载。1 @! I* T7 q+ K
4 J: y, z) }) m/ Q8 f( v" C
    进程一条普通指令的执行, 其实有一大家子在鞍前马后地忙碌着, 而进程几乎浑然不觉,真是太幸福了。! ~' f6 I# z+ G& _

5 m% f% w: p1 _2 ^( r1 e    扩展阅读:1 O2 S( g/ c' E' w
    书籍《深入理解计算机系统》, 《操作系统概念》
$ l) r; z. }4 n# T0 f( l9 f1 |$ K: \- H  K
    四、网络的核心概念

8 d; ]$ q. D4 H* r. q4 r+ C) f9 W, B2 r3 s8 q: B, k# u1 o
    上面所说的都局限于一台计算机, 然而一张大网早已经把这些孤岛联系在一起。这张大网就你我的周围, 我们都变成了它的一个节点。
. U, K0 Y! w/ [- T% {$ m- l1 n" j$ w7 d( Q& J! h6 D. g1 d. D9 r
    大网的设计非常有趣,没有一个中心的节点,某几个甚至某一片节点阵亡都没有关系,大网继续生存,提供服务。作为码农我们要理解的核心概念是: 分组交换, TCP/IP参考模型, socket , http(s)。
) l' O. Z! @) ?
- N! n1 o- w* R( j' M3 n    你也许没有想到,你上网玩游戏,听音乐,看这篇文章,其中的数据并不是一下子全发给你的, 而是被切分成适合网络传输的小块,给每个小块编上号, 每个小块都独立地走相同甚至不同的网络路径, 到达你这里,重新排序,组合,然后才展示给你,  这就是分组交换。3 Q% @8 {( v2 i+ B3 g6 V0 m) w5 E

' r8 g( P4 O6 w& B" s    使用分组交换可以充分的利用网络带宽: 在你不使用的间隙,别人也可以利用。
: x; D% ~0 w. Z9 }7 D6 z
$ n" u4 P  a: d: Y, {- F* }! ^    但是一个很明显的问题就是分组数据丢失了怎么办? 如何检测, 怎么重发,如何缓存已经收到分组数据等一系列烦人的问题接踵而来。  这就是TCP要干的事情。
+ D. y( v4 {) K: c$ X/ |
! L! P. B. W' J$ g5 I    如果你能体会到TCP是在端系统实现的,中间节点一无所知,我想你就Get到了分组交换和分层的真谛。
, L+ l8 i5 C) a2 B( g$ n
: [6 _9 ^6 G* e7 }4 v$ f    TCP/IP参考模型定义了5层: 应用层,传输层,网络层,链路层,物理层。你一定得理解所谓的分层只不过是把你的数据层层包装而已,在传输的过程层中每到一个节点都会拆开某一层的包装,查看一下数据, 然后再次包装,转发出去,直到终点。
6 C% ?' z( S7 h+ _# G% @$ n/ e9 Z9 b9 l' d& p- w2 W
    也许你不愿意了解底层烦人的细节, 但是一定要理解socket和http(s) , 这哥俩最贴近我们码农的日常生活,我们经常直接和他们对话,利用他们收发数据, 所以花点经历好好学学吧。2 l. C8 c% E/ M# ~. b2 \# @

" b9 c+ X6 z% ]) n. g1 a, C5 @) ?) V, o    图书:" n2 G& k1 o5 Q9 E  B
    《图解HTTP》
% `3 o# j; h* p2 O    《计算机网络:自定向下的方法》  e, G6 v9 z: k% K' C
! Z+ v* Z* Q! |0 d9 ~
    五、Hash 和 RSA3 j5 G- O5 O; _" F
4 e: l3 J7 G* t2 V( @
    如果说Https是网络安全通信的一大基石, 那Hash和RSA 则是基石的基石。为了保证消息在传输过程中的私密性, 完整性,不可伪造性,这哥俩可以说是功不可没。
: J8 ]/ o  g% M; t% i
1 ?; W" W- R9 C: D$ R; l    其实不仅仅是Https , 在各种软硬件平台上都能看到他们勤奋的身影, 例如SSO, SSH, JWT .....  所以非常值得你投入精力去学习。
& D' E2 J1 ?' t0 X% X  T3 d: Q
( F( \6 O7 r7 e) t: b+ ?; {    RSA最为美妙之处就是有一对儿钥匙, 一个是私有的、保密的, 另外一个是公有的, 谁都可以知道, 这对于之前的对称密钥是个极大的颠覆, 谁能想到原先需要保密的密钥竟然可以公开呢!
' @4 Q! G  L  N( R6 |& v0 E- U/ P
9 l& S, Z" B, e# H& j9 x    更有意思的是私钥加密的数据只有相应的公钥才能解开, 反之亦然,这确实是很漂亮的概念。" o% q; R, ]' C4 f& U

: D4 O+ X0 p- C' q4 u8 U3 ?( D+ j    RSA的概念很简单, 但是为了实现真正的安全消息传输,作为第一步必须得有数据签名做保证, 你需要理解如何对消息用Hash形成摘要,然后用私钥签名,又是如何验证这个签名的, 理解了这一点,很多东西都迎刃而解。
( f+ t+ R4 H2 B' {" Y8 y# b- C; r# j" J4 A1 k3 C4 T
上一篇
下一篇
帖子热度 1.4万 ℃

渡年 「出类拔萃」 2018-2-17 19:34 来自手机 |显示全部楼层

这个用户很懒,还没有填写自我介绍呢~


% [1 W  H+ n* s) y1 j! ]好帖 . f. B" f' S9 d" `8 j
很好帖
5 o" o' A0 P$ S& \1 b$ x: e" [2 u确实好帖
1 u$ D# x% ]- ~5 b1 Q少见的好帖
" t: d# J6 E0 \真 *** 好帖
$ l' m( U' L0 z: o难得一见的好帖 & E+ u2 e- q: J) u, K* |
千年等一回的好帖
0 I) D, k' B# M2 g# o/ X6 ^  W5 U好得不能再好的好帖 6 R& i2 ^$ |) A
惊天地且泣鬼神的好帖
* x8 f: N3 R! y# M) W( e! M4 \8 n% \让人阅毕击掌三叹的好帖 3 [! L9 l3 Q2 P( k1 A- p
让人佩服得五体投地的好帖 " Q; J. E/ z9 L5 n
让人奔走相告曰须阅读的好帖
2 ~/ `  E* J: J" r) M3 `让斑竹看后决定加精固顶的好帖
  I! v( J; a1 E/ K7 D4 L0 {让人看后在各论坛纷纷转贴的好帖
: q2 K5 ^; J3 w& F; @5 p$ ~让人看后连成人网站都没兴趣的好帖
5 N7 G1 |) t& s! J- R让人看完后就要往上顶往死里顶的好帖 0 V' ?7 j- R& F
让人看后不断在各种场合重复引用的好帖 4 Y/ r: [8 G2 U8 C
让人一见面就问你看过某某好帖没有的好帖 + V) I6 G; r7 W) z- s% O
让人半夜上厕所都要打开电脑再看一遍的好帖 4 j0 I$ C  ^9 p$ @  c9 H; `: {! g
让个读过后都下载在硬盘里详细研究欣赏的好帖 ! ]7 r  _) j$ Y4 f2 }
让人走路吃饭睡觉干什么事连做梦都梦到它的好帖
9 G: L9 r* r! H; L# Y8 [+ N6 g让人翻译成36种不同外语流传国内外世界各地的好帖
! W+ k) g$ t; b: \让人纷纷唱道过年过节不送礼要送就送某某帖子的好帖
8 T) h' J! e. T: I/ ^1 J让国家领导人命令将该帖刻在纯金版上当国礼送人的好帖
: z8 n( K6 j& m让网络上纷纷冒出该帖的真人版卡通版搞笑版成人版的好帖 7 t/ z7 w$ r: f. V( [0 M9 b
让人在公共厕所里不再乱涂乱化而是纷纷对它引经据典的好帖   ]: @* w- c  ^$ P
让某位想成名的少女向媒体说她与该帖作者发生过性关系的好帖 $ \  p2 J! x3 h, L, y6 E) q
让人根据它写成小说又被不同导演拍成48个不同版本的电影的好帖
5 P) J- x9 ~! \% {' \% i6 j#372:
站在记忆的边缘 「出类拔萃」 2018-2-18 14:13 来自手机 |显示全部楼层

这个用户很懒,还没有填写自我介绍呢~

第一次评论,
( g. n( o7 s" L% i好紧张啊,
+ T8 Y4 I* n. p; r1 g2 T' N( _/ Q9 a2 X

8 E7 f- K4 }, R6 z5 y该怎么说啊,$ l5 M2 b4 D  [$ S! J- K7 I5 m( m
5 F2 @/ r- l& c. C6 b
打多少字才显的有文采啊,
& n) g; D* X" G# a这样说好不好啊,
2 U9 G1 W7 x$ N. Q9 A) i! J% l+ g) e

# Q8 U* E4 t2 c; W; A3 g0 ~会不会成热贴啊,
5 b+ c' }0 v  U7 k& J
0 f" G0 ]5 {6 _+ [0 v我写的这么好会不会太招遥,' x9 |3 `: W/ B8 i( v/ a7 n
写的这么深奥别人会不会看不懂啊,7 R/ D1 b2 w" A
怎样才能写出我博士后的水平呢,0 e) s* @& F) W9 t
半年写了这么多会不会太快啊," l- E5 r: j3 n# R6 h$ S
好激动啊。#y424:#y424:
L155 「锋芒初露」 2018-2-28 14:55 |显示全部楼层

这个用户很懒,还没有填写自我介绍呢~

说句实话 没看懂
L155殷勤地给楼主揉揉肩捶捶背,楼主奖励1 个 金币.
一般男性 「初入古黑」 2018-3-30 22:48 |显示全部楼层

这个用户很懒,还没有填写自我介绍呢~

找不到这些书的资源啊
深蓝 炉火纯青 2020-1-17 22:49 来自手机 |显示全部楼层

一个男人没有丰富的面部表情,不代表他没有丰富的内心世界。

赞助会员
感谢分享。
您需要登录后才可以回帖 登录 | 免费注册  

本版积分规则

快速回复 返回列表