91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

好程序員Java培訓分享之RMI與RPC的區別

發布時間:2020-08-09 10:39:14 來源:ITPUB博客 閱讀:174 作者:好程序員 欄目:編程語言

  好程序員Java培訓分享 RMI與RPC的區別, 隨著java技術學習的不斷深入,越來越覺得保持初心是多么重要,無論我們學到哪個程度,在學習的時候始終保持初學者的心態,才能在自己的技術之上實現突破!

   今天有點像雞湯,回歸正題,繼續更新我的學習筆記:Java技術中的 RMI與RPC的區別。

一:RPC 遠程過程調用

RPC(Remote Procedure Call Protocol)遠程過程調用協議,通過網絡從遠程計算機上請求調用某種服務。

一次RPC調用的過程大概有10步:

1.執行客戶端調用語句,傳送參數

2.調用本地系統發送網絡消息

3.消息傳送到遠程主機

4.服務器得到消息并取得參數

5.根據調用請求以及參數執行遠程過程(服務)

6.執行過程完畢,將結果返回服務器句柄

7.服務器句柄返回結果,調用遠程主機的系統網絡服務發送結果

8.消息傳回本地主機

9.客戶端句柄由本地主機的網絡服務接收消息

10.客戶端接收到調用語句返回的結果數據

二:RMI 遠程方法調用

RMI:遠程方法調用(Remote Method Invocation)。能夠讓在客戶端Java虛擬機上的對象像調用本地對象一樣調用服務端java 虛擬機中的對象上的方法。

好程序員Java培訓分享之RMI與RPC的區別

RMI遠程調用步驟:

1,客戶調用客戶端輔助對象stub上的方法

2,客戶端輔助對象stub打包調用信息(變量,方法名),通過網絡發送給服務端輔助對象skeleton

3,服務端輔助對象skeleton將客戶端輔助對象發送來的信息解包,找出真正被調用的方法以及該方法所在對象

4,調用真正服務對象上的真正方法,并將結果返回給服務端輔助對象skeleton

5,服務端輔助對象將結果打包,發送給客戶端輔助對象stub

6,客戶端輔助對象將返回值解包,返回給調用者

7,客戶獲得返回值

三:RPC與RMI的區別

1:方法調用方式不同:

RMI中是通過在客戶端的Stub對象作為遠程接口進行遠程方法的調用。每個遠程方法都具有方法簽名。如果一個方法在服務器上執行,但是沒有相匹配的簽名被添加到這個遠程接口(stub)上,那么這個新方法就不能被RMI客戶方所調用。

RPC中是通過網絡服務協議向遠程主機發送請求,請求包含了一個參數集和一個文本值,通常形成“classname.methodname(參數集)”的形式。RPC遠程主機就去搜索與之相匹配的類和方法,找到后就執行方法并把結果編碼,通過網絡協議發回。

2:適用語言范圍不同:

RMI只用于Java;

RPC是網絡服務協議,與操作系統和語言無關。

3:調用結果的返回形式不同:

Java是面向對象的,所以RMI的調用結果可以是對象類型或者基本數據類型;

RMI的結果統一由外部數據表示 (External Data Representation, XDR) 語言表示,這種語言抽象了字節序類和數據類型結構之間的差異。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌拉特后旗| 辉南县| 高青县| 霍林郭勒市| 武汉市| 崇左市| 瑞金市| 鞍山市| 江达县| 临桂县| 改则县| 乌兰察布市| 读书| 乐平市| 罗平县| 嫩江县| 广南县| 轮台县| 灌南县| 忻城县| 贵州省| 景宁| 米泉市| 旬阳县| 札达县| 南宁市| 象州县| 兖州市| 天峨县| 英山县| 新泰市| 西乌珠穆沁旗| 章丘市| 浮梁县| 怀柔区| 安西县| 富顺县| 石楼县| 永登县| 阳谷县| 内江市|