Node學習基礎(一) 之瞭解nodejs

1. Node.js是什麼?

node.js是用於開發服務器,做數據API,設計路由...等

和前端的主要區別在於:前端主要負責效果和交互

2.Node.js是追求極致的產物

I,是單線程!!!

什麼是進程?
當一個程序開始運行時,它就是一個進程,進程包括運行中的程序和程序所使用到的內存和系統資源。
而一個進程又是由多個線程所組成的。

什麼是線程?
線程是程序中的一個執行流,每個線程都有自己的專有寄存器(棧指針、程序計數器等),但代碼區是共享的,
即不同的線程可以執行同樣的函數。

什麼是多線程?
多線程是指程序中包含多個執行流,即在一個程序中可以同時運行多個不同的線程來執行不同的任務,
也就是說允許單個程序創建多個並行執行的線程來完成各自的任務。

單線程

每個正在運行的程序(即進程),至少包括一個線程,這個線程叫主線程

主線程在程序啓動時被創建,用於執行main函數

只有一個主線程的程序,稱作單線程程序

主線程負責執行程序的所有代碼(UI展現以及刷新,網絡請求,本地存儲等等)。這些代碼只能順序執行,無法併發執行

單線程較多線程來說,系統穩定、擴展性極強、軟件豐富。多用於點對點的服務。

單線程就是一心一意,用情專一的癡情少年,多線程則相反。

單線程就是進程只有一個線程。

多線程與單線程的區別
生活舉例
你早上上班,正要打卡的時候,手機響了。。你如果先接了電話,等接完了,在打卡,就是單線程。
如果你一手接電話,一手打卡。就是多線程。
兩件事的結果是一樣的。。你接了電話且打了卡。

II,Non-blocking I/O   使用的是非阻塞IO ,異步IO

"++++++++++++++++++++++阻塞IO/非阻塞IO; 同步IO/異步IO +++++++++++++++++++++++++++ "
。IO請求的兩個階段:
1.等待資源階段:IO請求一般需要請求特殊的資源(如磁盤、RAM、文件),當資源被上一個使用者使用沒有被釋放時,IO請求就會被阻塞,直到能夠使用這個資源。
2.使用資源階段:真正進行數據接收和發生。

。在等待數據階段,IO分爲阻塞IO和非阻塞IO。
1.阻塞IO: 資源不可用時,IO請求一直阻塞,直到反饋結果(有數據或超時)。
2.非阻塞IO:資源不可用時,IO請求離開返回,返回數據標識資源不可用

。在使用資源階段,IO分爲同步IO和異步IO。
1.同步IO:應用阻塞在發送或接收數據的狀態,直到數據成功傳輸或返回失敗。
2.異步IO:應用發送或接收數據後立刻返回,數據寫入OS緩存,由OS完成數據發送或接收,並返回成功或失敗的信息給應用。

。IOPS,即每秒鐘處理的IO請求數量。IOPS是隨機訪問類型業務(OLTP類)很重要的一個參考指標。

 

III,Event Driven 事件驅動機制

從程序設計的角度來看,事件驅動模型的核心構件通常包含以下幾個:

  1. 事件源:負責產生事件的對象。比如我們常見的按鈕,按鈕就是一個事件源,能夠產生“點擊”這個事件

  2. 事件監聽器(事件處理器):負責處理事件的對象

  3. 事件:或者稱爲事件對象,是事件源和事件監聽器之間的信息橋樑。是整個事件模型驅動的核心

下圖展示了事件、事件源、監聽器直接的關係: 

事件驅動機制就是:
讓驢拉磨,它不拉,你用鞭抽一下,它就開始拉了。然後又停了,你再抽一下,它又繼續拉了
這叫用“鞭”驅動“驢”拉磨。
在程序裏,程序停止在那不動,你點擊一個按鈕,它就有反應了,過一會,又沒反應了,你再點一下,它又繼續運行。
這叫用“事件”驅動“程序”運行。

3.node和其他語言的後端語言不同(這點一定要記住)

有兩個特點:

第一個特點是: nodejs沒有自己的語法是用的是V8引擎,用的是js,V8引擎解析js,效率非常高,並且V8很多東西都是異步的,node就是站在巨人肩膀上把V8中的一些功能移植到了服務器上。

第二個特點是:沒有web容器,就是安裝配置完成之後,沒有一個根目錄。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章