讀軟體設計的要素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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...