主頁 > 後端開發 > 《迅雷鏈精品課》第三課:區塊鏈主流框架分析

《迅雷鏈精品課》第三課:區塊鏈主流框架分析

2020-11-12 12:36:08 後端開發

上一節課我們學習了區塊鏈的技術架構,系統地分析了區塊鏈平臺的6個層次:資料層、網路層、共識層、合約層、應用層、介面層,這節課我們將結合實際看看現在主流區塊鏈專案的技術架構;思考我們在設計具體的業務架構時,需要決定什么業務應該上鏈,什么業務應該用鏈下服務處理,一個簡單實用的判斷依據是回答以下3個問題:業務是否與信任或價值轉移相關?業務上鏈是否能提升效率?業務上鏈是否能降低成本?

在學習課程的時候,你也可以免費領取BaaS平臺為期一個月的試用機會,免費使用高性能區塊鏈服務(點擊鏈接即可免費領取https://blockchain.xunlei.com/baas/try.html),課程學習結合實踐操作,讓你迅速成為區塊鏈大牛!

*以下為第三課的內容~

第三課 區塊鏈主流框架分析

部分公鏈專案的技術架構概覽

按照上節課介紹的分層架構,我們來分析一下部分公鏈專案的技術架構,目前一些主流的公鏈專案的技術方案如下表所示:

在這里插入圖片描述
圖1. 主流的公鏈專案的技術方案

分析一個架構前,我們首先要明白,無論哪個區塊鏈專案,無論其采用哪種具體的技術方案,其核心功能都是維護一個分布式的賬本:資料層要保證賬本資料不丟失和不可篡改;網路層要保證網路規模的可伸縮性,新節點能方便加入,少數節點掉線不能影響系統的可用性;共識層要保證賬本資料的一致性;智能合約是對賬本資料進行修改的程式,因此合約層需要保證智能合約執行的確定性和可終止性等性質;應用層要結合賬本的性質,其業務應用應該與信任、資產或價值轉移相關,

限于篇幅,本文是概述性質的,重點介紹其創新性技術及其影響,讓你對各個專案架構變遷的主線有個大概了解,而上表包含的所有這些技術的細節都會在后續章節詳細分析,

位元幣

位元幣是首個以區塊鏈技術為基礎的數字貨幣系統,位元幣的技術架構是開創性的,后續的很多數字貨幣專案都是直接使用位元幣代碼,其它的區塊鏈專案也都繼承了位元幣系統的大部分概念,

根據位元幣白皮書所述,中本聰創建位元幣系統的目的,就是為了提供一種去中心化的,完全通過點對點技術實作的電子現金系統,以代替當前的法定貨幣+權威的中間機構的支付機制,所謂中間機構包括政府、銀行或任何提供支付擔保的服務商,中本聰為位元幣設計了一系列的技識訓制,包括UTXO交易模型、P2P網路、PoW共識演算法、用于驗證交易的腳本語言等,解決了電子貨幣的發行、流通、所有權驗證、防雙花、防篡改、激勵、安全信任等問題,

UTXO(Unspent Transaction Output,未花費交易輸出)是位元幣首創的資料模型,這是一種以資產為中心的記賬方式,

我們日常熟悉的銀行、信用卡、微信、支付寶、證券交易等都是基于賬戶的設計,在賬戶中保存個人資料、余額等資訊,比如A的賬戶有100元,B的賬戶有200元;現在A要轉10元給B,系統就將A的賬戶余額減去10元,B的賬戶余額加上10元,最后A的賬戶余額變成90元,B的賬戶余額變成210元,

而在UTXO 模型的加密貨幣中,某一個“賬戶”中的余額并不是由一個數字表示的,而是由當前區塊鏈網路中所有跟當前“賬戶”有關的 UTXO 組成的,在位元幣系統中,一個UTXO就是被所有者(某個用戶的錢包地址)鎖住或記錄于區塊鏈中的一定數量的位元幣,當用戶進行轉賬交易時,系統修改的是UTXO的所有者,而不是用戶的賬戶余額,
在這里插入圖片描述
圖2. UTXO交易示意圖,A給B轉8.5 BTC,用3個UTXO作為輸入,總輸入為9 BTC,輸出為2個UTXO:B收到8.5 BTC,A收到0.4 BTC作為找零,總輸入與總輸出的差額是交易手續費,

交易就像復式記賬法中的一個賬目,分為來源和去向兩個部分:每筆交易有一個或多個UTXO作為輸入,另一頭也是有一個或多個UTXO作為輸出;總輸出加上手續費等于總輸入,每個作為輸入的UTXO都是前面一筆或多筆交易的輸出,這樣每個UTXO都能追溯來源,最初的來源,就是某個礦工的挖礦所得,

中本聰并沒有向外界說明他設計UTXO模型的原因,但人們普遍認為這有助于交易的并行處理、在去中心化架構下更容易追溯資產來源,但難于支持圖靈完備的智能合約,

PoW(Proof-of-Work,作業量證明)的共識機制要求作業端進行一些耗時適當難度的對亂數的哈希散列函式計算,以尋找符合要求的亂數(哈希值的前綴要求存在一定數量的0),并且答案能被服務方快速驗算,以此耗用的時間、設備與能源做為擔保成本,以確保服務與資源是被真正的需求所使用,

位元幣系統的智能合約是非圖靈完備的,它不支持回圈陳述句或遞回呼叫、不能保存中間狀態,而是只有一條一條的簡單指令,用于執行簽名驗證等操作,

中本聰將UTXO的設計,跟區塊鏈、PoW共識演算法、智能合約和密碼學相結合,技術創新結合制度設計,首次創造了一個完整而嚴密加密貨幣體系和可信協議,為人們打開了區塊鏈創新的大門,

以太坊

以太坊最大的創新是推出了圖靈完備的智能合約語言Solidity和執行環境EVM,讓人們看到將區塊鏈技術用于加密貨幣以外的領域的可能性,

圖靈完備的智能合約意味著支持回圈陳述句和保存多階段中間結果的全域狀態,

在以太坊系統中,狀態是由被稱為“賬戶”(每個賬戶由一個20位元組的地址)的物件和在兩個賬戶之間轉移價值和資訊的狀態轉換構成的,以太坊的賬戶包含四個部分:

1) 亂數,用于確定每筆交易只能被處理一次的計數器(nonce);

2) 賬戶目前的以太幣余額(balance);

3) 賬戶的合約代碼,如果有的話(code);

4) 賬戶的存盤(storage);

以太坊有兩種型別的賬戶:外部所有的賬戶(由私鑰控制的)和合約賬戶(由合約代碼控制),外部所有的賬戶沒有代碼,人們可以通過創建和簽名一筆交易從一個外部賬戶發送訊息,每當合約賬戶收到一條訊息,合約內部的代碼就會被激活,允許它對內部存盤進行讀取和寫入,和發送其它訊息或者創建合約,

合約以賬戶的形式存在的方案意味著當一個智能合約被部署后,它成為了一個獨立存在的物體,它有自己的賬戶余額、有自己的存盤空間,這樣普通的用戶賬戶可以跟合約賬戶進行交易,普通用戶可以轉以太幣給合約賬戶、合約賬戶也能轉以太幣給普通用戶,它的所有交易記錄可以被獨立的追溯,

Hyperledger Fabric

Hyperledger Fabric專案是個面向企業應用場景的區塊鏈專案,是首個專注于聯盟鏈和私有鏈的開源專案,Fabric與其它公有鏈專案的思路有很大區別,為滿足企業的應用, Fabric考慮的主要需求包括參與者的認證、網路的許可權限控制、交易的隱私保護、監管、審計等方面,因此,Fabric架構的核心除了區塊鏈服務,包括賬本(LEDGER)、交易(TRANSACTIONS)、智能合約(SMART CONTRACT)以外,還有身份認證服務(IDENTITY),其架構圖如下所示:

在這里插入圖片描述
圖3. Hyperledger Fabric架構圖

PKI (Public Key Infrastructure)體系是一種綜合多種密碼學手段來實作安全可靠傳遞訊息和身份確認的一個框架和規范,Hyperledger Fabric的身份認證服務基于PKI體系構建,為整個區塊鏈網路提供身份管理、密碼學證書管理、認證、隱私、保密和審計的服務,公鏈專案的節點是匿名的、不可信任的,而Fabric網路中的節點需要首先獲得授權,節點間互相認識,

Hyperledger Fabric支持可插拔的共識協議,可以方便的針對某種特定應用場景和信任模型來配置合適的共識演算法,在單個企業內部或經過可信任的認證的情況下,拜占庭容錯的共識演算法是沒有必要的,它會影響性能;而在多方參與的場景中,則需要使用拜占庭容錯的共識演算法,目前Fabric支持拜占庭容錯的PBFT共識演算法和故障容錯的kafka共識演算法,其中PBFT是Fabric 1.0版本之前默認的共識演算法,支持3f+1節點集群(f為惡意節點數量);kafka共識機制是Fabric 1.0版本實作的共識演算法,它基于kafka訊息佇列集群對orderer節點提交的交易執行去重和排序操作,kafka集群使用zookeeper(Paxos演算法)做選舉,支持2f+1節點集群(f為故障節點數量),

Hyperledger Fabric的智能合約稱為chaincode,可用通用編程語言如Java、go、Node.js等撰寫,運行在docker容器中,這個方案是Fabric首創的,好處是讓開發者沒有額外的學習和培訓成本,并且和以太坊相比,Fabric鏈碼和底層賬本是分開的,升級鏈碼時并不需要遷移賬本資料到新鏈碼當中,真正實作了邏輯與資料的分離,

Hyperledger Fabric底層并不發行加密貨幣,而是以其完善的身份認證服務、可插拔的共識協議、方便管理的docker容器化的智能合約,可用于企業中廣泛的業務場景中,因此被公認為是區塊鏈3.0的典型的專案架構,

EOS

針對位元幣、以太坊等公鏈平臺的性能低、交易手續費高的問題,EOS推出了高性能、免交易手續的方案,

EOS的性能提升來自共識演算法改進和并發處理兩個方面,共識演算法方面,采用DPoS+aBFT共識演算法,選舉出21個超級節點作為投票節點,達到了0.5秒一個區塊的出塊速度;并發處理是采用了多執行緒并發處理的方案,方法是使用靜態分析來對交易按賬戶進行劃分(Shards),保證不存在兩個執行緒都包含同一帳戶下的交易,這樣一個區塊就可以并行的運行多個執行緒,經過這些優化后,EOS的實測性能可以接近4000 TPS,遠遠高于位元幣、以太坊等專案的性能,

EOS采用WASM作為智能合約的虛擬機,支持使用C++撰寫智能合約代碼,WASM是一種新的位元組碼格式,突出的特點就是精簡,加載時間短以及高速的執行模型,

迅雷鏈

根據實際情況和業務需求,迅雷鏈提出了獨有的同構多鏈架構結合DPoA + PBFT的共識機制,同構多鏈架構,即系統由一條條相對獨立(獨立進行共識)的鏈組成,每條鏈有多個節點,每個節點被分配到其中一條鏈上,不同的賬戶資料被錨定在不同的同構鏈上,然后接入層將交易路由到發送方所在的鏈上進行區塊打包與共識,其中每條鏈都運行獨立的DPoA + PBFT共識機制,迅雷鏈對PBFT演算法作出了一些優化,降低網路消耗,提高了演算法的可用性;DPoA共識機制是按各驗證人節點的存盤容量、網路穩定性、帶寬、時延、CPU使用率等指標作為衡量標準,選擇符合條件的驗證人節點,每輪投票都從其中動態選擇部分節點作為投票節點,以獲得更好的公平性和網路效率,在這樣的多鏈架構下,迅雷鏈的交易TPS性能可以達到百萬級別,交易秒級確認,
在這里插入圖片描述

圖5. 迅雷鏈的同構多鏈示意圖

智能合約方面,迅雷鏈同時支持EVM和WASM兩種虛擬機,因此用戶可以根據自己的實際情況選擇使用solidity或C/C++來撰寫智能合約,

區塊鏈3.0是超越貨幣、金融的應用領域,能夠為各行各業提供解決方案,全面服務于物體經濟,應用領域的擴大,也意味著業務模型會更龐大也更復雜,架構上也需要考慮更多的因素,例如:

  1. 用戶體驗,好的用戶體驗需要更快的回應速度、更安全的通信、更穩定的網路連接,因此迅雷鏈引入了接入層服務,負責客戶端的接入、鑒權、負載均衡、協議轉換等,在此基礎上搭建了迅雷鏈開放平臺,助力開發者快速開發、部署智能合約,企業或個人可以輕松將自己的產品和服務上鏈,更加便捷地開發區塊鏈應用,

  2. 海量資料存盤,迅雷鏈提供了高可靠、高安全性的TCFS(迅雷鏈檔案系統)以支持用戶存盤大量的檔案資料,

  3. 資料分析,負責對交易資料做統計分析、資料挖掘等處理,輸出統計報表,

  4. 監控服務,負責對節點和各個服務模塊做實時監控,檢測到例外后及時觸發告警,以便研發運維人員及時排除故障,保障服務的穩定運行,

考慮上述因素后,迅雷鏈架構如下所示(其中同構多鏈架構是屬于Layer 1層的改進,也就是每條子鏈都有一個獨立的Layer 1層):
在這里插入圖片描述

圖5. 迅雷鏈架構圖

區塊鏈應用的混合架構

在更具體的實際業務中,有些部分是機構的內部邏輯,實際會存在更多的鏈下服務,例如商城的用戶注冊、用戶人個資料、商品展示、運營管理、交易所的買賣單撮合、隱私資料等,都屬于鏈下的服務,需要和鏈上業務進行對接,

在這里插入圖片描述
圖6. 基于區塊鏈的業務的混合架構圖

上圖是典型的一個基于區塊鏈技術的應用業務架構圖:

應用服務包含所有的鏈下業務邏輯,可能非常龐大,例如包括供應鏈、客戶資料管理、訂單管理、商品展示等等,使用LAMP、微服務等成熟的技術進行開發;

業務資料庫可能包括MySQL、key-value資料庫等多種資料庫實體,用于存盤應用服務的業務資料;

區塊鏈網路負責交易的清結算,例如下單成功后的付款、資產轉移等,由具體的應用服務向區塊鏈發起交易請求;

對賬服務負責檢查需要上鏈的資料是否被區塊鏈網路正確處理,對漏發的、超時或未處理成功的資料應進行重發或差錯控制,以保障業務質量;

區塊資料分析服務用于構建區塊鏈資料分析服務,可以支持用SQL陳述句查詢分析資料,以支持對資料的復雜檢索,

結語

本文分析了一些具體的區塊鏈專案的技術架構,從區塊鏈1.0的位元幣網路,到區塊鏈2.0的以太坊、EOS,到區塊鏈3.0的Hyperledger Fabric和迅雷鏈,從上述的區塊鏈架構發展路徑,我們可以看到,隨著區塊鏈應用范圍的擴展,技術架構也越來越復雜,特別是鏈上鏈下混合的架構,是區塊鏈3.0全面服務于物體經濟的基本要求和重要特征,在設計具體的業務架構時,我們需要決定什么業務應該上鏈,什么業務應該用鏈下服務處理,一個簡單實用的判斷依據是回答以下3個問題:業務是否與信任或價值轉移相關?業務上鏈是否能提升效率?業務上鏈是否能降低成本?

歸根到底,區塊鏈提供的是機器信任,在此基礎上實作資產維護、價值轉移等業務,這些業務都是以提升效率和降低成本為目的,不是跟信任關系相關的業務、上鏈后無法提升效率和降低成本的業務,都可以認為是不適用于區塊鏈的,

*恭喜完成第三課的學習,第四課我們將深入了解區塊鏈的技術發展趨勢,討論共識機制、隱私保護、資料存盤和查詢分析、混合架構的探索及互操作性、以及標準化及規范化等技術內容,

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/211878.html

標籤:java

上一篇:NGK公鏈是什么專案,為什么這么多人玩?

下一篇:Vue的環境搭建及安裝程序

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more