讀軟體設計的要素02概念的目的

来源:https://www.cnblogs.com/lying7/p/18398757
-Advertisement-
Play Games

1. 要素 1.1. 概念的定義包括名稱、目的、狀態、操作和操作原則 1.2. 操作原則(operational principle) 1.2.1. 操作原則用於展示如何通過操作實現目的,這是理解概念的關鍵 1.2.2. 展示如何通過操作的組合實現概念的目的,包含一個或多個典型的使用場景 1.2.3 ...


1. 要素

1.1. 概念的定義包括名稱、目的、狀態、操作和操作原則

1.2. 操作原則(operational principle)

  • 1.2.1. 操作原則用於展示如何通過操作實現目的,這是理解概念的關鍵

  • 1.2.2. 展示如何通過操作的組合實現概念的目的,包含一個或多個典型的使用場景

  • 1.2.3. 操作原則並沒有增加任何信息,因為你完全可以從操作規範中推理出任何使用場景

1.3. 每個概念都是某人在某個時間出於某種目的而發明的

  • 1.3.1. 隨著時間的推移,大多數被廣泛使用的概念都得到了進一步的擴展和完善

1.4. 大多數概念是通用的,可以應用於不同類型的數據以及場景中

  • 1.4.1. 通用性有助於概念的重用,也有助於提煉概念的本質

1.5. 概念可以被相互獨立地設計和理解

  • 1.5.1. 為了簡化軟體設計,可以將設計分解成不同的子問題,許多子問題都可以通過概念的重用來解決

1.6. 概念並不能解決所有的設計問題,但是確實可以通過找出特定的概念來幫助我們發現設計中的挑戰

1.7. 概念不僅包含它表示的行為、關於其設計的所有現存知識、可能出現的實現問題,還包括軟體設計師處理這些問題的各種方法

1.8. 概念狀態(state),將概念中涉及的項目組織成各種結構

2. 廢紙簍

2.1. 蘋果公司的殺手級概念

2.2. 廢紙簍概念是蘋果公司在1982年為麗薩電腦發明的

2.3. 真正的創新並不是用戶可以把東西拖進廢紙簍,而是用戶還可以恢復它們

  • 2.3.1. 廢紙簍概念的目的並不是刪除,而是撤銷刪除

2.4. 在廢紙簍概念中,只有兩種狀態

  • 2.4.1. 可訪問(accessible),表示仍在廢紙簍以外、可以訪問的項目集合

  • 2.4.2. 已刪除(trashed),表示已刪除但尚未永久刪除的項目集合

2.5. 廢紙簍概念中有兩種場景

  • 2.5.1. 一種是恢復場景:刪除一個文件後再恢復它

  • 2.5.2. 一種是永久刪除場景:刪除一個文件後,再清空廢紙簍,用戶將再也無法訪問這個文件

2.6. 一種常見的變體就是,當刪除某個文件一段時間後,例如30天,系統就會自動永久刪除這個文件

2.7. 設計缺陷

  • 2.7.1. 整個系統只有一個廢紙簍

  • 2.7.1.1. 當你插入和移除外部驅動器時,如果從這些驅動器中刪除文件,廢紙簍的內容就會隨之變化

  • 2.7.1.2. 變通辦法,只是增加了一個“立即刪除”選項,允許用戶一鍵永久刪除廢紙簍中指定的文件

  • 2.7.2. 廢紙簍的另一個設計缺陷與已刪除文件的顯示方式有關

  • 2.7.2.1. 用戶一直沒有辦法按刪除日期對廢紙簍中的文件進行排序

  • 2.7.2.2. 2011年,蘋果公司的OS X Lion操作系統開始允許用戶按“創建日期”對文件夾中的文件進行排序,而這個日期對於廢紙簍而言就應該是文件刪除日期

3. 樣式

3.1. 桌面出版背後的概念

3.2. 樣式概念的狀態的映射關係

  • 3.2.1. 一種是指定(assigned),為元素指定一種樣式

  • 3.2.2. 另一種是定義(defined),為樣式定義一種格式

3.3. 樣式概念還在不斷豐富,甚至涉及一些格式的分層

4. 預訂

4.1. 一個19世紀的概念

4.2. 預訂概念有助於有限資源的有效利用

  • 4.2.1. 資源提供者希望資源利用率儘可能高

  • 4.2.2. 消費者希望有需要時就可以得到並使用資源

4.3. 預訂概念要起作用,就需要跟蹤與預訂相關的內容,包括被預訂的資源和預訂資源的消費者

  • 4.3.1. 消費者除進行預訂並最終使用資源之外,還可以在他們決定不需要資源的時候取消預訂

  • 4.3.2. 預訂通常是免費的,資源提供者還需要防止用戶總是預訂資源卻從不真正使用它

  • 4.3.2.1. 如果客人有太多次缺席,他的賬戶將被停用

4.4. 預訂概念的目的是有效利用資源

4.5. 預訂概念的操作原則是關於如何預訂並使用資源

4.6. 預訂概念的狀態是與預訂相關的全部內容

4.7. 預訂概念的操作:預訂、使用資源和取消預訂

  • 4.7.1. 預訂概念中的操作包括由資源所有者(如餐廳)執行的用於提供和回收資源的行為

  • 4.7.2. 資源在被預訂的情況下不能回收,但實際上更好的設計是允許回收,比如隱式地取消預訂

4.8. 預訂概念在很多不同的領域都非常有用

  • 4.8.1. 鐵路運輸要求列車在進入路段之前預訂軌道來保證安全,這樣系統就可以確保不會有兩列火車同時占用同一路段

  • 4.8.2. 在網路中,有一種資源預留協議(resource reservation protocol,RSVP),它允許路由器預訂帶寬,以便在某段時間內保證一定水平的網路性能,即“服務質量”​

5. 概念的目的

5.1. 以用戶需求為中心

5.2. purpose

  • 5.2.1. 目的對於生活的各個方面都很重要,因為目的可以幫助我們設定方向,向他人解釋自己,併在合作中達成共識

  • 5.2.2. 在目的這件事上,設計與其他活動沒有什麼不同,你不可能在自己都不知道想要什麼的情況下就設計好一件東西

  • 5.2.3. 對於軟體設計師來說,目的可以表明他們對概念的設計和實現方式是合理的

  • 5.2.4. 目的將要服務於誰?

  • 5.2.4.1. 通知概念聲稱是為用戶提供實時的更新,讓用戶隨時瞭解情況

>  5.2.4.1.1. 它的真實目的是提高“用戶參與度“
  • 5.2.4.2. 標簽概念的目的似乎很簡單,就是幫助人們更容易地找到特定人的帖子
>  5.2.4.2.1. 標簽概念巧妙地增加了兩組朋友間的社交關係

5.3. 概念設計首先要針對每個概念提出一個簡單的問題:它是做什麼用的?

5.4. 用戶瞭解一個概念的目的是使用它的先決條件

  • 5.4.1. 許多用戶手冊和幫助指南解釋了操作的細節,但沒有解釋目的,這對於用戶特別是新手來說很不友好

5.5. 一個概念的目的應該是有說服力、以需求為中心、具體和可評估的

  • 5.5.1. 概念的目的很少能夠用比喻解釋清楚

5.6. 沒有目的的概念是可疑的

  • 5.6.1. 出現這種情況通常是因為這個概念根本不是一個真正的概念,而是一種不想暴露給用戶的內部機制留下的痕跡

5.7. 對概念目的的混淆會導致誤用,並可能導致用戶做出令他們後悔的行為

5.8. 設計缺陷會導致概念無法實現其目的,但這是難以預料的,因為使用場景會隨著時間而變化

  • 5.8.1. 設計缺陷通常是不可預測的,這種缺陷既可能是形式與使用場景不符,也可能是概念無法實現它們的目的

  • 5.8.2. 概念並不能完全消除設計缺陷,但它的價值在於提供一個框架來減少設計缺陷,框架增強了概念目的的作用,並給出了一種把概念設計和使用中積累的經驗和知識組織起來的結構

5.9. 僅僅知道為什麼要設計軟體也是不夠的,你還需要為設計中的每個概念找到目的

  • 5.9.1. 為概念確定目的其實是一項困難的工作,但它會帶來解決問題的洞察力,並迫使我們專註於重要的事情

  • 5.9.2. 在軟體設計方面,由於它有無限的複雜性,人們很容易陷入細節並失去對大局的把控

6. 步驟

6.1. 說清楚

  • 6.1.1. 一個概念必須有明確的目的才會易於使用

  • 6.1.2. 軟體設計師不能將概念視為自己的秘密,必須與用戶共用目的

6.2. 確定目的的標準

  • 6.2.1. 目的總是與一定場景中人的需求相關,因此難以用邏輯或數學的方式評估,而只能以非正式或粗線條的方式評估

  • 6.2.2. 有說服力

  • 6.2.2.1. 目的應該是對一個明確的需求有說服力的表達,而不是對用戶的某些願望或可能要執行的操作的一些模糊表示

  • 6.2.3. 以需求為中心

  • 6.2.3.1. 目的必須表達用戶的某個需求,而不是僅僅重覆描述意義不明的行為

  • 6.2.4. 具體

  • 6.2.4.1. 目的必須足夠具體,以便於概念設計

  • 6.2.5. 可評估

  • 6.2.5.1. 目的應該能提供衡量概念的尺度

6.3. 深入理解目的

  • 6.3.1. 瞭解呼叫轉移概念的兩個不同目的

  • 6.3.1.1. 一種目的是委托轉移,允許一個人將對自己的呼叫委托給其他人

  • 6.3.1.2. 另一種目的是跟隨轉移,當一個人在不同的地方工作時,允許將對他的呼叫轉移到不同的位置

  • 6.3.1.3. 委托轉移概念和跟隨轉移概念都服務於自己的目的

7. 沒有目的的概念

7.1. 一個概念可能根本沒有令人信服的目的,這會讓人們對它的用處產生一些懷疑

7.2. 概念缺乏目的通常是因為沒有針對用戶真正的需求進行設計,而只是以一種更容易的方式設計

7.3. 無目的的概念是將底層機制暴露給用戶的結果

7.4. 概念需要始終面向用戶,並且它的目的不僅需要對程式員有意義,而且需要對用戶有意義

7.5. 老式的混水龍頭

  • 7.5.1. 如果你想提高溫度,你可以開大熱水水龍頭,關小冷水水龍頭,但是流量也會相應發生變化

  • 7.5.2. 如果你只想增加流量,則需要打開兩個水龍頭,仔細調整它們以重新達到所需的溫度

  • 7.5.3. 在這兩種情況下,用戶一般都需要進行多次調整

7.6. 新式的混水龍頭

  • 7.6.1. 龍頭具有兩個獨立的控制項,旋轉把手可以調節溫度,上下移動把手可以調節流量

7.7. 編輯器緩衝區(editor buffer)曾經是一個常見的概念,滿足了一些用戶需求,但現在它不再引人註意

  • 7.7.1. 無目的的編輯器緩衝區概念被淘汰了

8. 目的不明的概念

8.1. 如果用戶不清楚一個概念的目的,就很可能不按軟體設計師設計的方式使用

8.2. Twitter

  • 8.2.1. 事實證明,收藏概念的實際目的是記錄用戶對推文的認可,以供其他人查看,也就是通常所說的“喜歡”或“點贊”概念

  • 8.2.2. 書簽(bookmark)的新概念,該概念可以通過推文的“共用”菜單訪問

8.3. 一個目的不明的概念會產生混亂

  • 8.3.1. 圖像的解析度並不代表圖像的質量,除非你知道圖像的大小

  • 8.3.2. 像素陣列

  • 8.3.2.1. 圖像表示為彩色像素的二維陣列,這是一個現在普遍接受但曾經激進的想法

  • 8.3.3. 重新採樣是一種更複雜的操作,會改變像素的數量

  • 8.3.4. 圖像大小

  • 8.3.4.1. 它的目的是以物理尺寸描述圖像,這很簡單但也很奇怪,因為我們通常不認為數字圖像具有物理尺寸

  • 8.3.5. 圖像解析度本身並不是一個概念,而是假設圖像以給定的尺寸列印時的列印質量

  • 8.3.5.1. 果像素陣列為1000像素方陣,圖像大小為10英寸正方形,則解析度為100像素/英寸

8.4. 不要使用令人困惑的概念

  • 8.4.1. 誤解概念的目的很可能會導致濫用概念

9. 欺騙性的目的

9.1. 所有問答網站都有用戶概念,大概是為了阻止垃圾信息和低質量答案

  • 9.1.1. 網站會以此來限制訪問,以至於用戶在沒有登錄的情況下無法查看問題和答案,更不用說發佈新問題了

9.2. 推手民調是一個標準的民間調查,其目的是通過彙總民間的反應來獲得一些有用的信息

  • 9.2.1. 真正目的是贏得你的支持

  • 9.2.2. 推手民調通常是為了利益,通過問你一些暗示性的問題來改變你的觀點

9.3. 直達航班概念是由航空公司發明的,以響應早期的訂票系統,這種系統更偏愛只有一個航班號的航線

  • 9.3.1. 直達航班概念可以使航空公司的這些航線更加突出,從而使消費者更有可能購票

  • 9.3.2. 消費者不瞭解這個目的,沒有意識到直達不一定是直飛

10. 避免缺陷

10.1. 設計最好的結果是形式和場景之間完美契合,就像小朋友玩的木製拼圖,一塊塊緊密貼合

10.2. 你永遠無法完全預測設計中可能存在的缺陷,但你至少可以利用以前發現缺陷的經驗

10.3. 將設計分解為多個概念,這樣使設計適配的整體挑戰就可以簡化為一組更易於管理的子問題

10.4. 概念是可以重覆的,並可以提供跨場景的共性

10.5. 糟糕的設計導致的致命錯誤

10.6. 由場景變化引起的設計缺陷

10.7. 舊問題再次出現


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Angular 的路由復用策略(RouteReuseStrategy)是一種用於優化路由跳轉性能和提高用戶體驗的機制。通過實現RouteReuseStrategy介面,後可以自定義路由的復用行為,避免不必要的組件銷毀和重建,同時保持組件的狀態。 以下是對Angular路由復用策略的詳細介紹: 一、基 ...
  • 1. 概念的特性 1.1. 專一性原則(specificity principle)認為概念與目的應該一一對應 1.1.1. 專一性原則已被證明是概念設計中最有用的原則之一 1.1.2. 一個概念最多只能滿足一個目的 1.2. 很少有沒有目的的概念 1.2.1. 如果本應隱藏的用戶機制被暴露,可能會 ...
  • 1. 概念的關係 1.1. 概念是獨立的,彼此間無須相互依賴 1.1.1. 一個概念是應該獨立地被理解、設計和實現的 1.1.2. 獨立性是概念的簡單性和可重用性的關鍵 1.2. 軟體存在依賴性 1.2.1. 不是說一個概念需要依賴另一個概念才能正確運行 1.2.2. 只有當一個概念存在時,包含另一 ...
  • 模板方法模式(Template Method Pattern)也稱之為模板模式(Template Pattern),是設計模式中最簡單的模式之一。 先來看定義:定義一個操作中演算法的骨架(模板),將一些步驟延遲到子類中,模板方法使得子類可以不改變演算法的結構即可重新定義演算法某些特定的步驟。這個定義還是有 ...
  • 1. 概念的組合 1.1. 概念不像程式那樣,可以用較大的包含較小的 1.1.1. 每個概念對用戶來說都是平等的,軟體或系統就是一組串聯運行的概念組合 1.2. 概念是通過操作來同步組合的 1.2.1. 同步並不增加新的概念操作,但會限制已有的操作,從而消除一些獨立概念可能會出現的操作序列 1.3. ...
  • JDBC JDBC(Java DataBase Connectivty,Java資料庫連接)API,是一種用於執行Sql語句的Java API,可以為關係型資料庫提供統一的訪問,其由一組Java編寫的類和介面組成. JDBC驅動程式 起初,SUN公司推出JDBC API希望能適用於所有資料庫,但實際 ...
  • PLC Structured Text Object Oriented Programming PLC結構化文本(ST)——變數類型和變數屬性 變數類型 變數類型關鍵字 說明 外部讀寫 內部讀寫 VAR 內部變數,程式組織單元內部的變數 不允許 讀/寫 VAR_INPUT 輸入變數,由外部提供,在程 ...
  • PLC Structured Text Object Oriented Programming PLC結構化文本(ST)——臨時&靜態&實例-變數(TEMP&STAT&INST) 臨時變數(VAR_TEMP) 臨時變數在每次調用POU時都會初始化。 用在程式(PRG) 和 功能塊(FB) 中。 在方 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...