主頁 > 軟體設計 > 使用 OAS(OpenAPI標準)來描述 Web API

使用 OAS(OpenAPI標準)來描述 Web API

2020-09-13 03:41:49 軟體設計

無論哪種型別的Web API, 都可能需要給其他開發者使用. 所以API的開發者體驗是很重要的. API的開發者體驗, 簡寫為 API DX (Developer Experience). 它包含很多東西, 例如如何使用API, 檔案, 技術支持等等, 但是最重要的還是API的設計. 如果 API 設計的不好, 那么使用該API構建的軟體就需要增加在時間,人力,金錢等方面的投入. 有時候API會被錯用, 甚至帶來毀滅性后果. 最后抱怨該API等用戶越來越多, 慢慢的, 客戶就會停止使用該API. 

 

API的目的是讓人們可以簡單的使用它來達到自己的目的. 目前行業內有很多API風格, 例如: REST, gRPC, GraphQL, SOAP, RPC等等. 但是每個風格都遵循一些基本的設計原則. 

 

用戶就是上帝, 為用戶設計API 

和構建任何東西一樣, 你需要一個計劃, 你需要在真正做之前來決定你想要的是什么. API 設計也是一樣的. 

API 并不是用來盲目的暴露一些資料或業務處理能力. 它就像我們每天使用的任何形式的介面一樣, 例如微波爐的操作按鈕, 是來幫助用戶完成他們的目標的. 所以需要從用戶的視角來決定一個API的設計目標. 在整個設計程序中, 必須牢記以用戶的視角去設計, 如果以開發者的角度去設計, 那么問題就大了. 

 

如果以開發者的視角去設計的API, 那么通常的后果是開發出的API會很注重功能實作的程序和原理, 而不是用戶如何能簡單平滑的使用這個API來達到他們的目的. 所以一定要注重用戶的需求, 而不要讓內部實作細節, 原理什么的來騷擾用戶. 最后再次強調, 要設計出讓用戶容易理解和容易使用的API. 

所以 API 就是用戶看到的, 它表示出用戶能使用它做什么. API 的實作細節, 也就是如果完成的該功能的細節, 需要對用戶隱藏. 

 

識別 API 的目標 

記住首先考慮用戶的感受之后, 下面就需要考慮用戶能拿它來做什么了, 也就是識別API的目標.  

識別 API 的目標, 最基本的要對以下方面有深刻, 精準的認識: 

  1. Who, 誰可以使用這個API? 

  2. What, 用戶拿這個API能做什么事?  

  3. How, 用戶如何做這件事? 

  4. What need, 用戶想要做這件事的話還需要什么? 

  5. What return, 用戶會得到什么? 

 

1.就是指API的用戶, 4,5分別表示輸入輸出.  

 

針對2, 3解釋一下 

通常針對2.What(用戶拿API能做什么)可以導致(分解)多個3.How(多個步驟), 這樣的話每個步驟就是一個API的目標. 

比如說, 用戶想去淘寶買一個商品, 那么怎么買? 首先需要把商品添加到購物車, 然后再結賬. 那么這個API就應該有兩個目標: 添加商品到購物車, 以及 結賬. 

如果不這樣分解到話, 通常設計出的API會缺失一些目標. 

 

針對1, 也解釋一下 

首先應該識別出不同種類的用戶, 這里的用戶可能是人, 也可能是其他的程式. 通常通過檢查輸入和輸出就可以識別出用戶. 

 

總結一下就6個方面: 

  • 用戶 

  • 能做什么 

  • 如何做 - 分解步驟 

  • 輸入 

  • 輸出 

  • 目標 

 

避免從開發者角度設計API 

這部分包含幾個方面. 包括: 

  • 開發者所在公司的組織結構(參考康威定律) 

  • 資料, 例如資料使用了開發者所在公司內部的一些專有術語, 或者干脆把內部資料庫模型暴露了出來. 

  • 不要暴露實作細節, 避免受到業務邏輯實作細節的影響 

  • 避免受到軟體架構的影響, 比如說在開發者公司內部查詢產品名稱和產品價格是兩個API, 那么給用戶使用的API必須整合一下, 不能讓用戶分兩步查詢. 

 

最重要的還是要時刻牢記, 你所設計的這些東西都是用戶真正需要的嗎? 

 

 

下面切入正題: 

使用API描述格式來描述API 

這里我以RESTful風格的API為例. 想要了解使用ASP.NET Core 3.x 構建 RESTful API, 這里有一個教程(但是還沒講完) https://www.bilibili.com/video/av77957694/. 

 

很多人使用Excel或者紙和筆來進行API的設計作業. 但是如果想要在設計階段精準描述一個API, 尤其是它的資料, 那么最好使用一個結構化的工具, 例如API描述格式.  

API描述格式會為API提供一個標準化的描述, 并且它很像代碼. 它的優勢主要有: 

  • 有助于在專案團隊中共享設計 

  • 了解這種格式的人或者工具可以很簡單的理解它. 

 

針對REST而言, OpenAPI Specification(OAS) 就是一個非常流行API描述格式規范. 

 

OAS 

API描述格式是一種資料格式, 它的目標就是描述API. 

而OAS (OpenAPI Specification)是一個與編程語言無關的REST API描述格式. 它是由 OAI (OpenAPI Initiative) 所提倡的. OAI 是Linux基金會下面的一個組織, 專注于提供與供應商無關的描述格式. 而OAS則是社區驅動的一種格式, 任何人都可以做貢獻. 

 

OAS vs Swagger 

OAS 原來叫 Swagger Specification, 2015年11月這個格式被貢獻給了OAI, 并在2016年1月更名為 OpenAPI Specification. Swagger 規范最后的2.0版本就變成了 OpenAPI 2.0. 目前最新的OAS 應該是3.0大版本 

 

YAML 

OAS檔案可以使用YAML或JSON格式, 我使用YAML. 

 

像寫代碼一樣描述API 

OAS檔案就是一個文本檔案, 可以納入版本控制系統 ,例如 Git等. 所以在設計迭代的時候很容易進行版本管理和變化追蹤. 

 

編輯器 

OAS有一個在線的專用編輯器: http://editor.swagger.io/ 

@Swagger Ed 
itor. 
File , 
Edit 
Generate Server 
Generate Client 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
16 
17 - 
18 
19 
21 
23 
24 
25 
26 
27 
28 
29 
30 
SMARTBEAR 
Swagger: 
"2.0" 
info: 
description: 
more about 
"This is a sample server Petstore server. You can find out 
Swagger at Chttp://swagger.io](http://swagger.io) or on 
Circ. freenode.net, #swagger](http://swagger.io/irc/). 
For this 
sample, you can use the api key ?special-key' 
fi Iters . " 
version: 
"1.0.0" 
title: "Swagger Petstore" 
terms0fService : 
"http : //swagger. io/terms/" 
to test the authorization 
1.0.0 
Swagger Petstore 
[ Base URL: petstore . swagger. io/v2 J 
This is a sample server Petstore server. You can find out more about Swagger at bttp://swagger.io or on 
irc.freenode.net, #swagger. For this sample, you can use the api key special—key to test the 
contact: 
emai I : 
" apitean@swagger.10 
license: 
name: "Apache 2.0" 
url: 
host: "petstore . swagger. io" 
basePath: "/v2" 
tags : 
"pet" 
15- - name: 
" http : //www.apache.org/licenses/LICENSE-2. O. html " 
description: "Everything about your Pets" 
external Docs: 
description: "Find out more" 
"http : //swagger. io" 
url: 
20- - name: "store" 
description: "Access to Petstore orders" 
22 ? - name: "user" 
description: "Operations about user" 
external Docs: 
description: "Find out more about our 
url: 
"http : //swagger. to" 
schemes : 
"https" 
"http" 
naths: 
authorization filters. 
Terms of service 
Contact the developer 
Apache 2.0 
Find out more about Swagger 
Schemes 
HTTPS 
pet Everything about your Pets 
Authorize 
Find out more: http://swagger.io 
store" 
POST 
PUT 
/ pet 
/pet 
Add a new pet to the store 
Update an existing pet

左邊是代碼編輯區域, 右邊是渲染結果. 

 

但是我更習慣于本地編輯器, 我使用VSCode, 并安裝 Swagger Viewer 和 openapi-lint 兩個插件. 

EXPLORER 
v OPEN EDITORS 
GROUP 1 
{O one.yaml 
GROUP 2 
x Swagger Preview 
v OAS 
{n} one.yaml 
{O product.yaml 
{n} one.yaml X 
{O one.yaml > { } paths > (products > { } 
Swagger Preview - /Users/solenovex/OAS/one.yaml 
post > { } 
responses > { } 
or 
200 > 
- /Users/solenovex/OAS... 
1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
openapi: 3. ?.? 
info: 
title: "Shopping API" 
version 
: "l.?.??? 
paths: 
/products: 
description: The products catalog 
get: 
summary: Sea rch for products 
description: I 
Search for products in catalog 
using a free query parameter 
parameters: 
— name: free—query 
description: I 
A product 's name, reference, 
partial description 
in: query 
required: false 
schema : 
type: string 
responses: 
description: I 
desc 
Swagger 
SMARTBEAR 
Shopping API 
default 
I.o.o 
OAS3 
GET 
POST 
/products Search for products 
/ products Add P roduct 
Products matching free query parameter 
content: 
application/json: 
schema : 
type: array 
description: Array of products 
items : 
type: object 
description: A product 
required: 
reference 
— name

 

共享API描述API進行檔案記錄 

OAS檔案可以用來生成API對參考檔案, 這個參考檔案可以展示出所有可用的資源以及相應的操作. 通常我會使用Swagger UI, 它就是上圖右側的部分. 

 

生成代碼 

使用API描述格式進行描述的API, 其代碼也可以部分生成. 通常是一個代碼骨架. 

 

什么時候使用API描述格式 

肯定是在設計介面如何表達API目標和概念, 以及資料的時候. 

 

使用OAS來描述REST API的資源以及Action 

創建OAS檔案 

建立一個products.yaml檔案.  

然后在里面輸入 api 或 open等字串, 會出現兩個提示選項: 

products.yaml 
1 
api 
openapi, OpenAPI 3.0 lintable 
openapi, OpenAPI 3.0 minimal 
OpenAPI 3.0 minimal O

 

先選擇下面那個選項, 其結果是: 

products.yaml > { } paths 
1 
2 
3 
4 
5 
openapi: 3.?.? 
info: 
title: "API" 
versxon 1 
paths:
  • 第1行是Open API的版本 

  • 第4行 info 的 version 是指API的版本, 而info這個版本必須使用雙引號括起來, 否則OAS決議器會把它當成數字, 從而導致檔案驗證失敗(因為它的型別應該是字串). 

  • 第5行 paths, paths屬性應該包含該API可用的資源. 這里面使用 {} 僅僅是為了讓檔案驗證通過, 因為我目前還沒有寫什么內容. 在YAML里, {} 表示一個空的物件, 而非空的物件則不需要這對大括號. 

 

描述資源 

為了描述products這個資源, 就需要填寫paths屬性: 

1 
2 
3 
4 
5 
6 
7 
openapi: 3.?.? 
info: 
title: "API" 
version 
paths: 
/products: 
description: FR51J*l

這里description屬性不是強制的, 但是它可以用來描述該資源. 

 

描述資源的操作 

OAS檔案里描述的資源肯定包含一些操作, 否則檔案就不合理. 

看代碼: 

1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
3.?.? 
info: 
title: "API" 
version: "l.?.?" 
paths: 
/products: 
description: 
get: 
summa ry: 
description: I

 

我為/products這個資源添加了一個GET Action (get屬性), 然后我對這個get也進行了描述. 

summary相當于是對這個Action的一個概括性描述, 而description則能提供更詳細的描述資訊.  

這里description是支持多行文本的, 但是在YAML里面要想支持多行文本, 那么string屬性必須以 | 管道符 開頭. 

注意, 這里第1行 openapi下面的波浪線表示檔案驗證失敗. 

 

在OAS檔案里, 一個操作必須在responses屬性里提供至少一個回應: 

1 
2 
3 
4 
5 
6 
7 
8 
9 
l? 
11 
12 
13 
14 
15 
16 
17 
openapi: 3.?.? 
info: 
title: "API" 
version: 1 
paths : 
[products: 
description: 
get : 
summary: 
description: I 
responses: 
"2???? : 
description: I

一個Action可能有多種回應結果, 每種可能的回應結果都要在responses屬性中描述. 

每個回應都以狀態碼進行標識, 并且必須包含一個description屬性. 

注意: 狀態碼數字必須用雙引號括起來, 因為它的型別本應該是字串, 而這里的200是一個數字. 

 

下面我再添加一個POST Action: 

1 
2 
3 
4 
5 
6 
7 
8 
9 
l? 
11 
12 
13 
14 
15 
16 
17 
18 
19 
2? 
21 
22 
23 
24 
25 
26 
openapi: 3 .?.? 
info: 
title: "API" 
? "1.0.0" 
versxon : 
paths : 
/products : 
description: FR51J* 
get : 
summary: 
description: 
responses : 
"2???? : 
description: I 
post: 
summary: 
description: 
responses : 
"2???? : 
description: I

 

這里還是針對 /products 這個資源, 我就不過多解釋了. 

 

使用OpenAPI  JSON Schema 來描述 API 的資料 

OAS 依賴于 JSON Schema 標準來對所有的資料(查詢引數, body 引數, 回應body等)進行描述. 

 

注意, OAS 使用的其實是JSON Schema的一個子集, 并不包含所有的 JSON Schema 特性, 并且還添加了一些 OAS 獨有的特性到這個子集里. 
 

描述查詢引數 

如果我們的get操作里需要一些查詢引數(查詢字串, Query String), 那么可以使用 parameters 這個屬性: 

這里 parameters屬性是一個集合或陣列, 每個集合元素使用 - 開頭. 

為了描述一個引數, 至少需要name, in 和 schema 三個屬性. 在本例中, 還包含 required 和 description 兩個可選的屬性. 

  • in表示引數的位置, 這里值為query, 表述它是查詢字串(Query String, 例如 api/products?searchTerm=xxx).  

  • required 為 false 表示不是必填引數. required是可選的, 如果沒有寫的話, 那么它的值就是false. 但是最好還是寫上required屬性. 

  • 它的資料結構使用schema屬性來表示, 這里就是一個簡單的字串型別. 但是它其實是一個JSON schema, 所以它可以是復雜的物件型別. 

  • description屬性也是可選的, 但是最好還是寫上吧, 有個描述更好. 

 

使用JSON Schema來描述資料 

假設一個物件有三個屬性: 編號(string), 名稱(string), 價格(number). 那么使用JSON Schema來描述它就應該是這樣的: 

type: object 
propert les: 
type: string 
type: string 
id: 
name: 
price: 
type: 
number

 

還沒完, 我還必須指出屬性是否是必填的, 然后我再加上一個remark屬性, 它不是必填的: 

type: object 
requi red : 
— id 
— name 
— price 
properties: 
id: 
type: 
name: 
type: 
price: 
type: 
remark: 
type: 
string 
string 
number 
string

 

JSON Schema 通過 required 這個集合屬性來表示哪些屬性是必填的. 

 

此外, 我還可以在這里添加 description 和 example (示例)屬性: 

type: object 
description: 
required : 
— id 
— name 
— price 
properties: 
id: 
type: string 
description: FRfifiiR 
example: AC????I 
name: 
type: string 
exmaple: 
price: 
type: number 
example: 54.95 
rema rk : 
type: string 
exmaple:

 

此外 JSON Schema 還支持 物件屬性型別: 

type: obj ect 
description: —TFt% 
required: 
— id 
— name 
— price 
prope rt ies : 
id: 
type: string 
description: F%fifiiR 
example: AC????I 
name: 
type: string 
exmaple: 
price: 
type: number 
example: 54.95 
remark: 
type: string 
exmaple: 
manufacturer: 
type: object 
description: 
requi red : 
— id 
— name 
propert les: 
id: 
type: number 
description: %üId 
example: 123 
name : 
type: string 
exmaple:

 

JSON Schema 的東西比較多, 具體可以查找一下官方檔案. 

 

描述回應 

在OAS檔案里, 操作回應回傳的body里的資料是用content屬性來表示: 

22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
responses: 
" 2???? : 
description: I 
content: 
application/ j son: 
schema : 
type: array 
description: 
items: 
type: obejct 
description: 
required: 
— name 
— price 
— manufacturer 
properties: 
description: FRfiID 
type: string 
name : 
type: string 
price: 
description: 
type: number 
rema rk: 
type: string 
manufactu rer: 
type: object 
description: 
requi red : 
— name 
properties: 
id: 
type: 
name: 
type: 
number 
string

 

這里需要注意的就是該操作的結果是產品的陣列, 所以型別是array, 而array 的 items屬性就包含著陣列元素的schema. 

 

描述 body 引數 

像 POST 這樣的 Action, 它的引數是在請求的body里面. 

body引數需要使用 requestBody屬性描述, 看代碼: 

type: string 
61 
62 
post: 
63 
summary: 
description: I 
64 
65 
requestBody: 
66 
description: 
67 
68 
content : 
application/j son: 
69 
schema : 
7? 
required : 
71 
72 
— name 
— price 
73 
— manufacturerld 
74 
properties : 
75 
76 
name: 
type: string 
77 
price: 
78 
type: number 
79 
rema rk : 
8? 
type: string 
81 
82 
manufacturerld: 
83 
type: number 
84 
responses: 
85 
"200" : 
86 
description: I 
87

這個 body 引數的內容也是使用 JSON Schema來描述的. 

 

描述路由引數 

像 api/products/{productId} 這樣的URI里, productId就是一個路由/路徑引數. 

它可以這樣描述: 

5 
6 
64 
65 
66 
67 
68 
69 
7? 
71 
72 
73 
74 
75 
> 
paths : 
/products: 
/products/{p roductld}: 
description: 
delete: 
summary: 
parameters: 
- name: productld 
in: path 
required: true 
description: FhfiID 
schema: 
type: string 
components:

這里面name的值必須和 {} 里面的值一樣. 

in 的值為 path, 表示是路徑引數. 

路徑引數是必填的, 所以 required 為 true. 不然決議器會報錯. 

 

可復用組件 

OAS允許使用可復用的組件, 例如 schema, 引數, 回應等等, 使用它們的時候添加個參考就行. 

 

假設針對 /products 這個資源一共有兩個操作: 一個是回傳一組產品, 另一個回傳單個產品. 這時候回傳產品的JSON Schema就可以使用一個可復用的schema. 

可復用的組件要放在components區域, 它是OAS檔案的一個根級屬性. 看例子: 

89 
9? 
91 
92 
93 
94 
95 
96 
97 
98 
99 
l?? 
I?I 
1?2 
1?3 
1?4 
1?5 
1?6 
1?7 
1?8 
1?9 
110 
111 
112 
113 
114 
115 
116 
117 
118 
119 
120 
components: 
schemas : 
p roduct : 
type: object 
description: —TFt% 
requi red : 
— id 
— name 
— price 
- manufacturer 
properties : 
id: 
type: string 
description: FhfifiiR 
name: 
type: string 
price: 
type: number 
description: 
remark: 
type: string 
manufacturer: 
type: object 
description: 
required: 
— id 
— name 
properties: 
id: 
type: number 
name : 
type: Strind

這里面, 可復用的schema被定義在schemas屬性里, 每個可重用的schema的名字就是schemas的值, 這里就是product. 它下就包含著可重用的組件: 一個 JSON Schema. 

 

參考定義好的schema 

參考定義好的schema需要使用到JSON參考. JSON參考這個屬性的名字是$ref, 它的值是一個URL. 這個URL可指向本檔案內部甚至外部的組件. 這里我只參考檔案內部的組件. 

 

62 
63 
64 
65 
66 
67 
68 
84 
85 
86 
87 
88 
89 
91 
92 
93 
post: 
summary: 
description: I 
requestBody: 
description: 
content: 
responses: 
"2???? : 
description: I 
content: 
application/ j son: 
schema : 
$ref: 'W/ components/schemas/product' 
components : 
schemas:

 

而針對那個 get Action的回傳結果(陣列型別), 需要把JSON參考放在 array 的 items屬性里. 

 

可復用引數 

直接看代碼: 

65 
66 
67 
68 
69 
70 
71 
1?2 
1?3 
104 
105 
106 
1?7 
108 
109 
description: 
delete: 
summa ry: 
pa ramete rs : 
— $ref: "#/components/parameters/productl?' 
components: 
> schemas: 
parameters: 
productld: 
name: productld 
in: path 
required: true 
description: F%ID 
schema : 
type: string

和可復用schema類似, 可復用引數也放在components下面, 它所在的區域是 parameters. 其參考方式也類似, 就不過多介紹了. 

 

除了在Action級別參考可復用引數, 在資源這個級別也可以這樣做: 

6 
64 
65 
66 
67 
68 
69 
70 
/products: 
/products/{productld}: 
description: 
pa rameters : 
— $ref: "#/components/parameters/productld" 
delete: 
summary: 
components:

 

預覽 

 

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

標籤:架構設計

上一篇:實戰_Spring_Cloud

下一篇:StarUML之一、UML的相關基本概念

標籤雲
其他(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)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more