色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深入理解RESTful Api設計

Android編程精選 ? 來源:Java建設者 ? 作者:微笑刺客D ? 2022-06-14 15:43 ? 次閱讀

REST

REST(REpresentational State Transfer)是 Roy Fielding 博士于 2000 年在他的博士論文中提出來的一種軟件架構風格(一組架構約束條件和原則)。在該論文的 中文譯本 中翻譯是"表述性狀態移交"。

ee0b2168-eb0c-11ec-ba43-dac502259ad0.png

原則

  • 網絡上的所有事物都被抽象為資源
  • 每個資源都有一個唯一的資源標識符
  • 同一個資源具有多種表現形式(xml,json 等)
  • 對資源的各種操作不會改變資源標識符
  • 所有的操作都是無狀態的

資源(Resources)

資源是一種信息實體或者說是一個具體信息,能夠被想象出名字。比如多個圖書館,那么便是可使用的圖書館資源,而圖書館內,多個樓層,那么便擁有了多個樓層的資源,各樓層提供了不同服務,那么服務也是資源。在互聯網中,可以用一個 URI(統一資源定位符)指向它,每種資源對應一個特定的 URI(如同一本書,按照書頁碼去定位哪一頁,目的是定位資源)。訪問這個特定 URI 便獲取到了這個對應的資源。

表述(REpresentations)

資源的表述是一段對于資源在某個特定時刻的狀態的描述,通過表述捕獲資源,并在組件間(客戶/服務器)移交該表述。表述有多種格式,如 HTML/XML/JSON/純文本/圖片/視頻/音頻等。具體的表述格式,可以在 HTTP 請求頭信息中用 Accept 和 Content-Type 字段指定,請求/響應方向的表述通常使用不同的格式。

狀態移交(State Transfer)

對于組件間而言(客戶/服務器),資源的請求是一個互動過程。通過表述捕獲資源當前或是預期的狀態,相當于獲得了資源的狀態。通過移交代表資源的表述,來將資源在組件的兩者之間進行傳遞,進而改變應用狀態。如當客戶端獲取了資源后,自身狀態處于穩定,當再次獲取資源后自身狀態再次處于穩定。客戶端操作并對服務端發起請求,在資源上執行各種動作而打破資源自身狀態,達到客戶端操作所期望狀態。

RESTful Api

與 REST 相比多了一個 ful,就英語層面來說是一個形容詞,RESTful 翻譯成中文為“REST 式的”,滿足了 REST 架構風格的應用程序設計的 Api 則便是 RESTful Api,即 REST 式的 Api。

以往 Api 設計

在 MVC 項目中,經常都是設計成動賓結構給 ajax 調用

/getCustomers
/getCustomersByName
/getCustomersByPhone
/getNewCustomers
/verifyCredit
/saveCustomer
/updateCustomer
/deleteCustomer

可有時卻因為沒有統一的規范,多人協作時,對于動詞的描述上也沒有統一,時長出現了類似如下的各類叫法,不能說這種情況有什么弊端,畢竟這種方式也是正常工作著。

/getCustomers
/getAllCustomer
/getCustomerList
/getPagedCustomer
/queryCustomers
/queryAllCustomers
/queryCustomerList
...

相比之下,RESTful Api 提供了更為標準化,規范化的 URL 寫法。

設計規范

考慮 Api 設計時,URI 中不能有動詞,URI 的目的是定位資源,而具體的對資源的操作,是借助 HTTP 的動詞完成,與早期 Api 設計相比,本身的思路是不同的,原來更多的是考慮函數式編程或者叫做面向行為的服務建模,比如 RPC,遠程調用一個函數,那么 Api 設計便是會考慮為動詞名詞格式,而對于 REST 風格來講,是面向資源的服務建模。而對于資源而言,可以是對象、數據或是查詢服務。

HTTP 動詞

對于一個系統而言,對外提供的功能總體上劃分為兩類:

  • 獲取系統資源,主要包括讀取資源和資源描述信息。
  • 對系統資源進行變更,主要包括寫入資源,對已有資源狀態的變更,刪除已有資源。ee2ccc96-eb0c-11ec-ba43-dac502259ad0.png

對于這其中使用到的一些動詞,使用 HTTP 的動詞描述來承擔對資源執行的行為,動詞通常使用以下幾種。對于 HTTP1.1 規范中的其他幾個動詞(如 OPTIONS 等)則不再介紹。

  • GET: 獲取目標資源。
  • HEAD: 獲取(傳輸)目標資源的元數據信息。該方法與 GET 相同,但是不傳遞內容體。
  • POST: 創建新資源,對于復雜查詢而言,提交查詢表單給查詢服務也是常用 POST 的(當然其他幾個能做的它也能做)。
  • PUT: 替換已有資源(整體)。
  • PATCH: 修改已有資源(局部)。
  • DELETE: 刪除資源。

URI

URI 作為統一資源標識符,其本質是標識資源,就像進入圖書館,任一本書都應具有在哪個樓層,哪個區域,哪個書架等等標識信息,來唯一確定這本書,于資源而言,更是如此,對于 URI 的設計,規范是使用名詞來定位資源,比如常見的

GET/Api/Users/{id}

這樣便按照 id 值,來唯一定位這一 Useree46a990-eb0c-11ec-ba43-dac502259ad0.png

對于資源的單復數格式,盡管規范是盡可能使用復數,但并沒有說哪條紀律或是約束限制說一定要使用復數,這無需強制約束,按照自身統一即可。畢竟有些不可數名詞,沒有復數格式,那么還是沿用本身,而對于整體風格為復數下,卻又顯得格格不入。

面向資源

資源的組織決定著 URI 的展示方式,對于底層數據庫而言,也許 Order 模型有若干張表來支撐存儲,對外總體是提供著 Order 服務。這樣一來,如果按照底層數據庫表來考慮 Api 設計,則會陷入無盡的關系處理中,比如 Order 下有 OrderItem,OrderItem 下有 OrderItemAttachment,如果按照這個思路去實現 Api 設計時,那么 URI 的設計上則會存在多級情況。

POST/Api/Orders
POST/Api/Orders/{id}/OrderItems
POST/Api/Orders/{id}/OrderItems/{itemId}/OrderItemAttachments
POST/Api/Orders/{id}/OrderItems/{itemId}/OrderItemAttachments/{}/...
...

于數據庫而言,表與表間構成了一張龐大的網,有時還不好找到定位資源的入口ee57e11a-eb0c-11ec-ba43-dac502259ad0.png

如果按照單表進行 URI 設計,那么則成了面向表服務建模,這又造成了底層的服務細節統統對外暴露,因此需要避免創建僅反映數據庫內部結構的 API。

在領域驅動設計中,聚合這一概念,將具有強相關的實體和值對象納入到一起,形成獨立空間、業務邏輯內聚于聚合之中,同生共死。面向聚合進行 Api 設計,多級路由的嵌套結構緩和許多,如需求上考慮 Order 創建時一定需要有 OrderItem 的存在,那么則對于這兩者而言是捆綁的關系,而對于 OrderItemAttachment 而言,不是必要的。

ee80037a-eb0c-11ec-ba43-dac502259ad0.png

那么則可以獨立設計聚合(此處忽略底層數據庫中表是如何設計的,僅考慮聚合),URI 的設計也圍繞著聚合這一資源來進行,這樣一來,URI 的設計便成了如下結構

POST/Api/Orders
{
"locationId":1,
"productIds":[
1,
2,
3
]
}

POST/Api/Orders/{id}/OrderItems
{
"productIds":[
4,
5,
6
]
}

POST/Api/OrderItemAttachments
{
"orderItemId":1,
"fileUrl":"xxx"
}

嵌套層級結構不會太深,因為太深的層級結構往往也意味著這個聚合的設計或許存在一點問題。

約束設計

對于 Post、Put、Patch 和 Delete 這些操作來講,面向聚合設計 URI 基本可以有路可循。

比如以下一些常見的 URI

POST/Api/Orders
POST/Api/Orders/{id}/OrderItems
POST/Api/OrderItemAttachment
PUT/Api/Orders/{id}
PUT/Api/Orders/{id}/OrderItems/{itemId}
PUT/Api/OrderItemAttachments/{id}
PATCH/Api/Orders/{id}/Address
PATCH/Api/Orders/{id}/OrderItems/{id}/Amount
PATCH/Api/OrderItemAttachments/{id}/FileUrl
DELETE/Api/Orders/{id}
DELETE/Api/Orders/Batches
DELETE/Api/Orders/{id}/OrderItems/{id}
DELETE/Api/OrderItemAttachments/{id}
POST/Api/Invites/emailTemplate

PATCH/Api/Invites/{id}/Sendmail//Sendmail作為郵件服務資源
PATCH/Api/Notifications/{id}/MessageStatus
PATCH/Api/Notifications/MessageStatus/batches
PATCH/Api/Orders/{id}/OrderItem/{itemId}/PayStatus

POST/Api/Orders/exports//返回導出資源
POST/Api/exportServices//提交給導出服務資源
POST/Api/exportServices/Sendmail
POST/Api/InviteParseServices//提交給解析服務資源

...

當然也有一些夾雜著動詞,習以為常的 Api 設計,如果習慣了,不想改變,仍然可以使用著動詞(后續提到該部分違反約束),但若想改變,就得換個思路去考慮設計了

POST/Api/Account/Login
POST/Api/Account/Logout
POST/Api/Account/Register

比如,Login/Logout 操作的目標資源是什么?如果把登錄的用戶當作在系統中存儲的資源來看便可以認為已上線的用戶信息,取個資源名字,在線用戶(onlineUser),然后對其執行行為。而對于 Register 來講,則更是容易轉換了,注冊本身是對 Account 的操作行為,其本質是創建一個沒有過的用戶。那么直接去掉注冊即可了,如認可改變可以按照如下設計,如仍習慣現有,則不改即可,并沒有什么約束、紀律限制說一定要遵循。

POST/Api/Accounts
POST/Api/OnlineUsers
//如下需要結合Authorization,不直接在URI中傳遞參數
DELETE/Api/OnlineUsers

主要是對于查詢類的操作,設計起來復雜一些,無論是實際開發中還是按照二八原則,大部分操作都是查詢操作,并且查詢起來天馬行空。

先是以下簡單的查詢

GET/Api/Orders
GET/Api/Orders/{id}
GET/Api/Orders/{id}/OrderItems
GET/Api/Orders/{id}/OrderItems/{id}

//篩選
GET/Api/Orders?Name=xxx&LocationId=xxx
//分頁
GET/Api/Orders?Page=1&Limit=10
//也可以拆分成如下兩個此處資源為Page
GET/Api/Orders/Page?Page=1&Limit=10
GET/Api/Orders/PageCount?Page=1&Limit=10
//排序
GET/Api/Orders?Sort=Name%20DESC
GET/Api/Orders?Sort=Name%20DESC,CreationTime%20ASC

然后再為一些常見場景下的(對于查詢類的,聚合的邊界應消失了,更多的應該是將各種資源串聯起來)

//UI上需要知道某個資源是否存在
GET/Api/Orders?name=xxx
HEAD/Api/Orders?name=xxx
能夠查詢到狀態碼返回204
找不到狀態碼返回404

//文件下載
GET/Api/OrderFiles/{id}/Url

//報表分析(將報表分析的結果作為虛擬資源)
GET/Api/AnalyseResults

//返回指定條件下的總數
GET/Api/Locations/{id}/OrderCount?Status[]&Status[]=2&CreationTime=2022-05-01

//UI上下拉框所需要的基礎數據
GET/Api/Locations/Names?page=1&limit=30&search=xxx
{
"id":"xxx",
"name":"xxx"
}

//獲取最近的循環周期
GET/Api/Plans/{id}/LatestCycleDate

//獲取最近的記錄(根據時間,狀態過濾后的第一條)
GET/Api/Orders/Latest

...

實際使用中,算了算也只有百分之八十左右的接口是按照 RESTful Api 的規范使用著的,總是有些接口,不能或是難以用簡單的描述就能解決。比如如下幾個接口,我便直接違反著約束(不能有動詞,只能使用名詞)。

PATCH/Api/Invites/{id}/Approval
PATCH/Api/Invites/{id}/Decline
PATCH/Api/Invites/{id}/Reject
...

Github中也還是有動詞描述https://docs.github.com/en/rest/codespaces/codespaces#start-a-codespace-for-the-authenticated-user

https://docs.github.com/en/rest/codespaces/codespaces#stop-a-codespace-for-the-authenticated-user

https://docs.github.com/en/rest/checks/runs#rerequest-a-check-run

https://docs.github.com/en/rest/checks/suites#rerequest-a-check-suite

如果按照這幾個約束條件來看的話,僅當滿足三個約束條件的才能認為是 RESTful Api,而滿足一個或是兩個約束條件的為 Http Api,那么我們或許是一直在追隨 RESTful Api 的路上了。

ee8f2d64-eb0c-11ec-ba43-dac502259ad0.png

面對這部分難以描述或是無法組織的接口,個人認為直接違反一些約束即可,總歸是只有少部分接口僅滿足一個到兩個約束。

狀態碼

HTTP 中使用狀態碼來表示著請求的成功與否,我們可以直接使用它,而無需在返回值中再包裹一層 code/message,盡管在 mvc 中,我也很喜歡這么做。

{
"code":200,
"message":"",
"data":{

}
}

對 HTTP 的狀態碼接觸越多后,越發覺得思路偏了,不應該將請求響應的狀態碼與業務中行為的成功與否進行隔離開,因為 HTTP 本身是應用層協議(超文本移交協議),是為業務服務的。如何在網絡層面上把一個請求發送出去,再接收到響應,這是 TCP 協議來保障的。假設網絡層如果請求失敗了,那么應用層都無法進行,因此結合狀態碼與返回內容(當出現異常時仍然返回狀態碼與錯誤描述信息)。如下 HTTP 的狀態碼覆蓋了絕大部分場景。當客戶端需要追蹤問題時,查看對應請求的狀態碼,結合其對應的解釋說明,便可以去定位相關的問題,當然,前提是真的返回了符合場景下的狀態碼。

  1. Informational responses (100199)
  2. Successful responses (200299)
  3. Redirection messages (300399)
  4. Client error responses (400499)
  5. Server error responses (500599)

在 Api 中,100 階段的狀態碼不會涉及,具體的各響應碼參見如下圖

eedef5b0-eb0c-11ec-ba43-dac502259ad0.pngimg

版本號

對外提供的資源服務地址需要存在版本控制,以便于客戶端應用能夠訪問到對應的資源,版本號的規劃有如下幾種方式,具體使用哪種得依靠具體的情況而分析:

  1. 不考慮版本,內部使用、短暫的生命周期下不考慮資源的變更或是直接對資源本身進行了換新如此變更到新的 url 上。
  2. 為每個資源的 URI 添加一個版本號。
GET/Api/v2/Orders/{id}
  1. 作為查詢字符串參數來指定資源的版本
GET/Api/Orders/{id}?version=2
  1. 在 http 的 header 中增加自定標頭設置版本號。
GET/Api/Orders/{id}
Custom-Header:version=2

成熟度模型

2008 年,Leonard Richardson 為 Web API 提出了以下 成熟度模型 :

  • Level 0: 定義一個 URI,所有操作是對此 URI 發出的 POST 請求。
  • Level 1: 為各個資源單獨創建 URI。
  • Level 2: 使用 HTTP 方法來定義對資源執行的操作。
  • Level 3: 使用超媒體(HATEOAS: 「H」ypermedia 「A」s 「T」he 「E」ngine 「O」f 「A」pplication 「S」tate,參見 HATEOAS - Wikipedia )。

誠然,對于這個成熟度模型,我一般都只會去達到前三個級別,雖然 Roy Fielding明確表示 ,Level 3 才是真正的 RESTful Api,對于 Level 3 級別,其實并沒有理解到其具體奧妙。因為我們面對的是 UI,用 UI 去鏈接操作,那么對于 Level 3 返回的超媒體而言,又如何表現呢?

原文標題:Restful 是什么??

文章出處:【微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 軟件架構
    +關注

    關注

    0

    文章

    64

    瀏覽量

    10291
  • REST
    +關注

    關注

    0

    文章

    32

    瀏覽量

    9422
  • Restful
    +關注

    關注

    0

    文章

    11

    瀏覽量

    3549

原文標題:Restful 是什么??

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    深入理解C語言:循環語句的應用與優化技巧

    能讓你的代碼更加簡潔明了,還能顯著提升程序執行效率。本文將詳細介紹C語言中的三種常見循環結構——while循環、for循環和do...while循環,帶你深入理解
    的頭像 發表于 12-07 01:11 ?182次閱讀
    <b class='flag-5'>深入理解</b>C語言:循環語句的應用與優化技巧

    socket 與 RESTful API 的使用

    在現代網絡應用中,數據傳輸和通信是核心功能之一。為了實現這一功能,開發者通常會使用兩種主流的技術:Socket和RESTful API。 1. Socket的概念和特點 1.1 Socket的概念
    的頭像 發表于 11-12 14:22 ?305次閱讀

    深入理解 Llama 3 的架構設計

    最新的自然語言處理(NLP)技術和深度學習算法,旨在提供更加自然、流暢和智能的對話體驗。 1. 核心組件 Llama 3的架構設計可以分為以下幾個核心組件: 1.1 預處理模塊 預處理模塊負責將原始文本數據轉換為模型可以理解的格式。這包括文本清洗
    的頭像 發表于 10-27 14:41 ?564次閱讀

    深入理解FPD-link III ADAS解串器HUB產品

    電子發燒友網站提供《深入理解FPD-link III ADAS解串器HUB產品.pdf》資料免費下載
    發表于 09-06 09:58 ?1次下載
    <b class='flag-5'>深入理解</b>FPD-link III ADAS解串器HUB產品

    錫焊原理解析:深入理解電子產品制造的核心工藝

    探索焊接技術在精密電子工程中的重要性和創新,從基礎元件的連接到現代焊接技術的進展,深入了解焊接材料的選擇與焊接技術的分類。本文提供了對錫焊原理的深入分析,揭示了高質量電子產品制造的關鍵因素。
    的頭像 發表于 08-12 15:03 ?732次閱讀
    錫焊原<b class='flag-5'>理解</b>析:<b class='flag-5'>深入理解</b>電子產品制造的核心工藝

    深入理解FFmpeg閱讀體驗》

    一、編譯X264 H.264是ITU(International Telecommunication Union,國際通信聯盟)和MPEG(Motion Picture Experts Group,運動圖像專家組)聯合制定的視頻編碼標準。而X264是一個開源的H.264/MPEG-4 AVC視頻編碼函數庫,是最好的有損視頻編碼器之一。 先直接從網絡(http://download.videolan.org/pub/videolan/x264/snapshots/)獲取X264源碼。考慮到版本關系,本文我下載的是x264-snapshot-20180430-2245-stable.tar.bz2。 tar -vxf x264-snapshot-20180430-2245-stable.tar.bz2 mkdir x264 手動創建的X264文件夾用于存放編譯后的X264庫。執行如下命令: ./configure --host=aarch64-linux --prefix=/home/x264 --enable-shared --disable-asm --enable-static --cross-prefix=aarch64-linux-gnu- 之后執行make make install完成x264庫的交叉編譯。生成的文件信息如下: root@EliteDesk800:~/x264/lib$ ls libx264.solibx264.so.152pkgconfig root@EliteDesk800:~/x264/lib$ file * libx264.so:symbolic link to libx264.so.152 libx264.so.152: ELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, BuildID[sha1]=01dd733d65c98eb894b4cdd41216259543ec8405, with debug_info, not stripped pkgconfig:directory 二、編譯FFmpeg 首先從FFmpeg官方網站http://ffmpeg.org/download.html上下載FFmpeg源碼。 tar -vxf ffmpeg-snapshot.tar.bz2 mkdir ffmpeg_install 其中ffmpeg_install文件夾用于保存生成的文件。執行如下命令: ./configure --prefix=/home/ffmpeg_install --enable-cross-compile --arch=arm64 --target-os=linux --cc=aarch64-linux-gnu-gcc --disable-x86asm --cross-prefix=aarch64-linugnu---pkg-config=/usr/bin/pkg-config --pkg-config=/usr/bin/pkg-config主要用于解決ERROR: x264 not found using pkg-config問題,網上很多解決方法都不靠譜。 之后執行make make install完成ffmpeg的交叉編譯。 生成的文件信息如下: root@EliteDesk800:~/ffmpeg$ file ../ffmpeg_install/bin/* ../ffmpeg_install/bin/ffmpeg:ELF 64-bit LSB executable, ARM aarch64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-aarch64.so.1, for GNU/Linux 3.7.0, BuildID[sha1]=b32285f11866f79dd499330849a9b3195ea0e446, stripped ../ffmpeg_install/bin/ffprobe: ELF 64-bit LSB executable, ARM aarch64, version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux-aarch64.so.1, for GNU/Linux 3.7.0, BuildID[sha1]=5d3fa4ea21ad6c4395bbaf134b915190799305b2, stripped
    發表于 04-16 22:54

    深入理解 Sora 的技術原理

    將去除噪音后的結果數據,利用視頻解碼器進行解碼,將低維潛在空間數據還原成原始視頻數據,這里可以實現不同分辨率的視頻解碼。
    的頭像 發表于 04-05 09:19 ?1967次閱讀
    <b class='flag-5'>深入理解</b> Sora 的技術原理

    深入理解 FPGA 的基礎結構

    轉載地址:https://zhuanlan.zhihu.com/p/506828648 文章很詳細的介紹了FPGA的基礎結構,能更直觀的理解內部結構原理。對深入學習很有幫助。 以下是正文: 這一段
    發表于 04-03 17:39

    深入理解數據備份的關鍵原則:應用一致性與崩潰一致性的區別

    深入理解數據備份的關鍵原則:應用一致性與崩潰一致性的區別 在數字化時代,數據備份成為了企業信息安全的核心環節。但在備份過程中,兩個關鍵概念——應用一致性和崩潰一致性,常常被誤解或混淆。本文旨在闡明
    的頭像 發表于 03-11 11:29 ?946次閱讀
    <b class='flag-5'>深入理解</b>數據備份的關鍵原則:應用一致性與崩潰一致性的區別

    深入理解GPIO原理和運用

    GPIO允許我們的單片機與外部世界進行通信,它是我們控制外部設備和接收外部信號的接口。
    的頭像 發表于 02-19 16:12 ?1931次閱讀
    <b class='flag-5'>深入理解</b>GPIO原理和運用

    恒訊科技帶大家深入理解:WebSocket服務器的工作原理

    WebSocket是一種在單個TCP連接上進行全雙工通信的通信協議。它的設計目標是在Web瀏覽器和服務器之間提供低延遲、高效的雙向通信。下面是深入理解WebSocket服務器工作原理的一些關鍵概念
    的頭像 發表于 01-29 16:48 ?490次閱讀

    深入理解FFmpeg閱讀體驗》ffmpeg安裝

    書中講了如何編譯安裝,我看了一下比較復雜,所以下載安裝包進行安裝,下載網址:Download FFmpeg 下載完后解壓出來在bin目錄下面有三個文件: 復制這個目錄: C:\\\\Users\\\\liujianhua\\\\Downloads\\\\ffmpeg-6.1.1-essentials_build\\\\ffmpeg-6.1.1-essentials_build\\\\bin 打開環境變量: 將剛才復制的地址添加進去 到此就安裝結束,測試一下是否安裝成功,打開shell輸入ffmpeg -version就可以看到輸出信息:
    發表于 01-25 21:35

    深入理解光耦模擬隔離放大電路的技術奧秘

    深入理解光耦模擬隔離放大電路的技術奧秘 ?編輯 ▲ 圖1 仿真原理圖二、原理分析 之所以這個電路圖看起來容易讓人感到困惑,實際上就是這個仿真電路中,錯誤的使用了這樣的光電三極管來表示HCNR201
    發表于 01-10 10:12

    深入理解FFmpeg閱讀體驗》初識有感

    言中《如何閱讀本書》指出我們如何開始學習FFmpeg。老師建議從頭開始,上篇為基礎篇,下篇為API使用以及開發。 第三,書中還給我們指出如何從FFmpeg官方文檔、wiki以及推薦雷霄驊博士的學習資料。 經過閱讀前面幾章,讓我感覺入門FFmpeg應該學習資料非常之多,只要認真的學習,應該可以掌握這門技術。
    發表于 01-07 19:48

    深入理解FFmpeg閱讀體驗》+ 書收到了,嶄新的開篇

    今天收到了《深入理解FFmpeg》 嶄新的書,一個在2022年較近距離接觸過卻尚未深入研究的領域圖像處理。最近剛好在作這方面的研究,希望自己可以把握這次機會,好好學習下 FFMpeg,相信可以讓自己
    發表于 01-07 18:57
    主站蜘蛛池模板: 成人免费视频在线观看| 亚洲精品免播放器在线观看| 日韩AV片无码一区二区三区不卡 | 国产综合无码一区二区色蜜蜜| 欧美成人无码视频午夜福利| 亚洲精品影院久久久久久| 久久国产高清视频| 亚洲精品美女久久777777| 捆绑白丝粉色JK震动捧喷白浆| 亚洲色欲色欲www474ee| 国产白丝JK被疯狂输出视频| 日本xxxx69动漫| 9久久99久久久精品齐齐综合色圆| 九九99热久久精品在线6| 午夜国产羞羞视频免费网站| cntv官网| 秋霞午夜理论理论福利无码| 1区2区3区4区产品不卡码网站| 果冻传媒在线完整免费播放| 8050午夜二级一片| 免费国产成人高清在线观看视频| 又黄又猛又爽大片免费| 精子网久久国产精品| va亚洲va天堂va视频在线| 欧美性视频xxxxhd| 不用播放器的黄| 全彩黄漫火影忍者纲手无遮挡| 国产情侣真实露脸在线| 学生小泬无遮挡女HD| 国色天香社区视频免费高清3 | seyeye免费高清观看| 亚洲裸舞 hd| 三级视频黄色| 东北真实仑乱| 校园刺激全黄H全肉细节文| 国产日韩在线欧美视频| 97在线视频免费| 日本wwwhdsex69| 久久成人免费大片| 国产精品一区二区AV白丝在线| 一个人在线观看的视频|