農林漁牧網

您現在的位置是:首頁 > 林業

計算機原理大彙總

2022-10-13由 麗水龍哥 發表于 林業

如何理解補碼的含義

計算機專業的那六大件:組成原理,作業系統,資料庫,編譯原理,計算機網路,資料結構, 其次還得加上分散式的基礎知識, 因為現在的系統都變成分散式的了。如果你是做應用層開發的,那幾門課程中的有些內容和日常工作關聯度不大,我挑那些最重要的來說一說,也算是一個最小集合吧!

1,計算機組成原理

如果你不是做作業系統/驅動程式的,直接和硬體打交道的機會很少,因為作業系統已經把他們遮蔽掉了,提供了抽象的API給我們使用。

但是還必須理解馮諾依曼體系的結構,CPU和記憶體,硬碟,各種外設之間的關係,暫存器、快取等知識。CPU有哪些指令,如何執行這些指令,如果實現陣列,結構體,函式呼叫,這就涉及到彙編的知識。像原碼,反碼,補碼,定點數、浮點數的表示和運算也是程式設計中必備的知識,幾乎每種語言都要涉及。

現在很多語言都是在虛擬機器上執行的,你只要是瞭解了計算機的組成原理,再去看哪些虛擬機器,就會發現概念都是相通的。另外CPU中的快取,快取一致性協議,DMA的非同步思想都會在應用層中有所體現。《編碼》是一個更加科普性,但是也更2,作業系統

作業系統是比較枯燥的, 站在應用層的角度,我認為重點是掌握作業系統對外提供的抽象,包括程序、執行緒,檔案,虛擬記憶體,以及程序間的通訊問題。幾乎所有的程式語言都會涉及到對多程序或者多執行緒程式設計的支援, 特別是多執行緒的併發程式設計,所以必須得搞明白他們的本質是什麼,執行緒都有哪些實現方式。得真正地體會到“程序是資源分配的最小單位,執行緒是排程的最小單位。” 這句話的含義。

幾乎所有的程式語言都會涉及到鎖和死鎖,最好在最底層理解鎖是怎麼實現的。需要理解虛擬記憶體和物理記憶體直接的關係,分段和分頁,檔案系統的基本原理。對於程序的排程,頁面分配/置換演算法,磁碟的排程演算法,I/O系統,我認為優先順序比較低。

3,計算機網路

必須要理解的是這些:

什麼分組交換。

TCP可靠性傳輸原理,TCP/IP的協議細節, 三次握手,四次揮手,TCP狀態轉換。

幾個重要的協議DHCP,UDP, ARP, DNS。

能夠說出一個客戶端如何在接入網路以後,透過這些協議,跨域網路和伺服器通訊的。

和應用層結合非常緊密的Socket知識和網路安全(對稱加密,非對稱加密,Hash, 數字簽名,以及集大成者Https)

至於網路層的路由選擇演算法,鏈路層的各種協議,我認為優先順序比較低。

以上這些知識,在你學習Redis ,Ngnix, Tomcat, LVS等軟體時將有極大的幫助。

加有趣的講組成原理的書。

計算機原理大彙總

4,資料庫

這個和日常工作結合極其緊密,不用我再多說,包括最基本的SQL,各種正規化,事務及其隔離級別,事務的實現方式,索引及其實現方式,B+樹等等。

5,編譯原理

你一輩子也許都不會去寫一個編譯器,但是很有可能會利用現成的工具去生成/操作一個抽象語法樹(AST),甚至可以會寫一個DSL(領域特定語言)。所以你的理解詞法分析、語法分析、語義分析,中間程式碼生成,程式碼最佳化這個基本編譯的過程。

計算機原理大彙總

6,分散式的理論知識

由於現在的系統慢慢地變成了分散式, 所以又擴展出了很多相關基礎知識需要學習:

6。1,資料複製與一致性:

CAP理論, BASE原則,冪等性, 2PC, TCC,Paxos , Raft , Gossip

6。2,資料分片和路由:

Hash分片:Hash取模(實際中非常常見的演算法), 虛擬桶(Redis使用),一致性Hash(memcached使用)

7,最後想說的是,不能帶著特別功利的目的去學習這些基礎,不能想著立刻、馬上就應用到實戰中,從中獲益。更重要的理解掌握它們背後的思想!