Bài giảng Phân tích và thiết kế hướng đối tượng - Bài 2: Khái quát về UML - Đào Nam Anh

Phương pháp hướng đối tượng và quá trình phát triển hệ thống phần mềm 1. Giới thiệu về hệ thống phần mềm 2. Sự phát triển hệ thống 3. Các cách tiếp cận trong phát triển phần mềm 4. Quá trình phát triển phần mềm hợp nhất Ký hiệu (notation)  Ký hiệu (notation) cho phép thể hiện ý tưởng phức tạp một cách ngắn gọn và chính xác.  Trong các dự án liên quan đến nhiều người tham gia, có kiến thức, kỹ thuật và văn hóa khác nhau, trao đổi thông tin có nguy cơ bị hiểu sai lệch, nên sự chính xác và rõ ràng là rất cần thiết

pdf89 trang | Chia sẻ: candy98 | Lượt xem: 707 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Bài giảng Phân tích và thiết kế hướng đối tượng - Bài 2: Khái quát về UML - Đào Nam Anh, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
PHÂN TÍCH VÀ THIẾT KẾ HƯỚNG ĐỐI TƯỢNG OBJECT ORIENTED ANALYSIS AND DESIGN DR. DAO NAM ANH Bài giảng 2: KHÁI QUÁT VỀ UML 1 RESOURCE - REFERENCE 1. Ian Sommerville, Software Engineering, Ninth Edition, 2011 2. Bernd Bruegge & Allen H. Dutoit. Object-Oriented Software Engineering: Using UML, Patterns, and Java, Third Edition, Prentice Hall, 2010 3. Russell C. Bjork, ATM Simulation Links, Gordon College 4. Hans-Erik Eriksson, Magnus Penker, Brian Lyons, David Fado, UML 2 Toolkit, John Wiley & Sons Inc, 2003 5. Dương Kiều Hoa – Tôn Thất Hoà An, Phân tích và thiết kế Hệ thống thông tin với UML, 2006 6. Đào Nam Anh, Giáo Trình Phân Tích Và Thiết Kế Hướng Đối Tượng, Đại học Điện lực, 2013 2 CONTENT – NỘI DUNG Phương pháp hướng đối tượng và quá trình phát triển hệ thống phần mềm 1. Giới thiệu về hệ thống phần mềm 2. Sự phát triển hệ thống 3. Các cách tiếp cận trong phát triển phần mềm 4. Quá trình phát triển phần mềm hợp nhất 3 Ký hiệu (notation)  Ký hiệu (notation) cho phép thể hiện ý tưởng phức tạp một cách ngắn gọn và chính xác.  Trong các dự án liên quan đến nhiều người tham gia, có kiến thức, kỹ thuật và văn hóa khác nhau, trao đổi thông tin có nguy cơ bị hiểu sai lệch, nên sự chính xác và rõ ràng là rất cần thiết. 4 Ký hiệu (notation)  Để một ký hiệu có thể dùng chính xác trong trao đổi thông tin, ký hiệu đó phải có một ngữ nghĩa xác định, phải là đại diện thích hợp cho một khía cạnh nhất định của hệ thống, và nó phải được hiểu rõ với tất các thành viên tham gia dự án.  Khi một ký hiệu trở thành chuẩn mực, được sử dụng bởi một số lượng lớn người tham gia, thì khả năng hiểu sai và mơ hồ là rất ít.  Ngược lại, khi có nhiều ký hiệu có cùng nghĩa, hoặc khi có một ký hiệu rất đặc biệt, người sử dụng dễ hiểu lầm vì mỗi người có cách giải thích riêng của mình. 5 Unified Modeling Language  UML (ngôn ngữ mô hình hóa thống nhất, Unified Modeling Language) cung cấp một dải các ký hiệu đại diện cho các khía cạnh khác nhau của một hệ thống và đã được chấp nhận là một ký hiệu tiêu chuẩn trong công nghiệp. 6 Lịch sử hình thành UML Kết quả của sự thống nhất của  OMT (Object Modeling Technique), Rumbaugh và cộng sự năm 1991,  Booch năm 1994, và  OOSE (Object-Oriented Software Engineering) Jacobson và cộng sự năm 1992.  UML cũng đã bị ảnh hưởng bởi các ký hiệu theo định hướng đối tượng khác, chẳng hạn như Mellor và Shlaer năm 1998, Coad và Yourdon năm 1995,  Wirfs Brock năm 1990, Martin và Odell năm 1992. 7 Lịch sử hình thành UML 8 Unifield Modeling Language - UML  UML là một ngôn ngữ mô hình hóa thống nhất có phần chính bao gồm những ký hiệu hình học, được các phương pháp hướng đối tượng sử dụng để thể hiện và miêu tả các thiết kế của hệ thống.  Đó là một ngôn ngữ để đặc tả, trực quan hoá, xây dựng và làm tư liệu cho nhiều khía cạnh khác nhau của một hệ thống.  UML có thể được sử dụng làm công cụ giao tiếp giữa người dùng, nhà phân tích, thiết kế viên và lập trình viên. 9 Unifield Modeling Language - UML  UML cung cấp hệ thống ký hiệu chuẩn có thể được sử dụng bởi tất cả các phương pháp hướng đối tượng và để lựa chọn và tích hợp các yếu tố tốt nhất của từ các ký hiệu trước đó.  Ví dụ, UML có các biểu đồ Use Case của OOSE và sử dụng nhiều tính năng của các biểu đồ lớp của OMT.  UML cũng bao gồm các khái niệm mới không được trình bày trong các phương pháp khác tại thời điểm đó, chẳng hạn như cơ chế mở rộng và một ngôn ngữ các hạn chế. 10 UML - ngôn ngữ mô hình  UML sử dụng các mô hình để xác định các yêu cầu của người dùng đối với hệ thống và qua đó giúp chúng ta đánh giá tính khả thi của dự án.  Tầm quan trọng của mô hình đã được lĩnh hội một cách thấu đáo trong hầu như tất cả các ngành khoa học kỹ thuật từ nhiều thế kỷ.  Khi muốn xây dựng một vật thể nào đó, đầu tiên cần tạo ra các bản vẽ để quyết định cả hình thức và phương thức hoạt động của nó.  Mô hình nhìn chung là một cách mô tả vật thể. Vật thể đó có thể tồn tại trong một số giai đoạn nhất định, như giai đoạn thiết kế hay giai đoạn xây dựng hoặc chỉ là có trong kế hoạch.  Thiết kế viên cần phải tạo ra các mô hình mô tả tất cả các khía cạnh khác nhau của sản phẩm.  Ngoài ra, một mô hình có thể có nhiều hướng nhìn, mỗi hướng nhìn sẽ mô tả một khía cạnh riêng biệt của sản phẩm hay hệ thống cần được xây dựng.  Một mô hình cũng có thể được xây dựng trong nhiều giai đoạn và ở mỗi giai đoạn, mô hình sẽ được bổ sung thêm một số chi tiết nhất định. 11 UML - ngôn ngữ mô hình Mô hình đảm bảo các yếu tố:  Chính xác (accurate): Mô tả chính xác hệ thống cần xây dựng,  Đồng nhất (consistent): Các mô hình, hướng nhìn khác nhau không được mâu thuẩn với nhau,  Có thể hiểu được (understandable): Dễ hiểu cho những người tham gia phát triển,  Dễ thay đổi (changeable),  Dễ dàng kết nối với các mô hình khác. 12 UML - ngôn ngữ mô hình Mô hình hóa một hệ thống nhằm mục đích:  Hình dung một hệ thống theo thực tế hay theo mong muốn,  Chỉ rõ cấu trúc hoặc cách ứng xử của hệ thống,  Tạo một khuôn mẫu hướng dẫn nhà phát triển trong suốt quá trình xây dựng hệ thống,  Ghi lại các quyết định của nhà phát triển để sử dụng về sau. UML chính là một ngôn ngữ mô hình. 13 Lĩnh vực ứng dụng UML  Hệ thống thống tin (Information system): Cất giữ, lấy, biến đổi biểu diễn thông tin cho người sử dụng. Xử lý dữ liệu lớn có các quan hệ phức tạp, được lưu trữ trong các cơ sở dữ liệu quan hệ hay hướng đối tượng .  Hệ thống kỹ thuật (Technical system): Xử lý và điều khiển các thiết bị kỹ thuật như viễn thông, hệ thống quân sự, hay các quy trình công nghiệp. Đây là loại thiết bị xử lý các giao tiếp đặc biệt, không có phần mềm chuẩn và thường là các hệ thống thời gian thực (real time).  Hệ thống nhúng (Embeded system): Thực hiện trên phần cứng gắn vào các thiết bị như điện thoại di động, điều khiển xe hơi. Điều này được thực hiện bằng lập trình mức thấp với hỗ trợ thời gian thực. Những hệ thống này thường không có các thiết bị như màn hình đĩa cứng. 14 Lĩnh vực ứng dụng UML  Hệ thống phân tán (Distributed system): Được phân bố trên một số máy cho phép truyền dữ liệu từ nơi này đến nơi khác một cách dễ dàng. Hệ thống này có cơ chế liên lạc đồng bộ để đảm bảo sự toàn vẹn dữ liệu và thường được xây dựng trên một số các kỹ thuật đối tượng như CORBA, COM/DCOM, hay Java Beans/RMI.  • Hệ thống giao dịch (Business system): Mô tả mục đích, nguồn lực (con người, máy tính), các quy tắc (luật pháp, chiến thuật, cơ chế), và công việc hoạt động nghiệp vụ.  • Phần mềm hệ thống (System software): Định nghĩa cơ sở hạ tầng kỹ thuật cho phần mềm khác sử dụng, chẳng hạn như hệ điều hành, cơ sở dữ liệu, giao diện người sử dụng. 15 Lĩnh vực ứng dụng UML UML được sử dụng trong ba loại mô hình hệ thống:  Các mô hình chức năng, được thể hiện trong UML với biểu đồ Use Case, mô tả các chức năng của hệ thống từ quan điểm của người sử dụng.  Các mô hình đối tượng, được thể hiện trong UML với biểu đồ lớp, mô tả cấu trúc của hệ thống bằng các đối tượng, các thuộc tính, các liên kết, và các hoạt động.  Các mô hình động, được thể hiện trong UML với biểu đồ tương tác, biểu đồ trạng thái, và biểu đồ hoạt động, mô tả các hành vi nội bộ của hệ thống. 16 UML và các giai đoạn phát triển hệ thống Tập hợp yêu cầu  UML dùng Use Case để nắm bắt các yêu cầu của khách hàng. UML sử dụng biểu đồ Use case (Use Case Diagram) để nêu bật mối quan hệ cũng như sự cách thức giao tiếp với hệ thống.  Trong Use case, các tác nhân (Actor) bên ngoài quan tâm đến hệ thống sẽ được mô hình hóa song song với chức năng mà họ đòi hỏi từ phía hệ thống (tức là Use case). Các tác nhân và các Use case được mô hình hóa cùng với các mối quan hệ và được miêu tả trong biểu đồ Use case của UML. 17 UML và các giai đoạn phát triển hệ thống Giai đoạn phân tích  quan tâm đến quá trình trừu tượng hóa, hình thành các lớp và các đối tượng cũng như cơ chế hiện hữu trong phạm vi vấn đề.  Sau khi nhà phân tích đã nhận biết được các lớp thành phần của mô hình cũng như mối quan hệ giữa chúng với nhau, các lớp cùng các mối quan hệ đó sẽ được miêu tả bằng biểu đồ lớp (class diagram) của UML.  Sự cộng tác giữa các lớp nhằm thực hiện các Use case cũng sẽ được miêu tả nhờ vào các mô hình động (dynamic models) của UML. Trong giai đoạn phân tích, chỉ duy nhất các lớp có tồn tại trong phạm vi vấn đề (các khái niệm đời thực) là được mô hình hóa.  Giai đoạn này chưa xét đến các lớp kỹ thuật, định nghĩa chi tiết cũng như giải pháp trong hệ thống phần mềm, ví dụ như các lớp cho giao diện người dùng, cho ngân hàng dữ liệu, cho giao tiếp. 18 UML và các giai đoạn phát triển hệ thống Thiết kế  Kết quả của giai đoạn phân tích sẽ được mở rộng thành giải pháp kỹ thuật.  Các lớp mới sẽ được bổ sung để tạo thành hạ tầng cơ sở kỹ thuật: Giao diện người dùng, các chức năng để lưu trữ các đối tượng trong ngân hàng dữ liệu, giao tiếp với các hệ thống khác, giao diện với các thiết bị ngoại vi và các máy móc khác trong hệ thống.  Các lớp thuộc phạm vi vấn đề có từ giai đoạn phân tích sẽ được "nhúng" vào hạ tầng cơ sở kỹ thuật này, tạo ra khả năng thay đổi trong cả hai phương diện: Phạm vi vấn đề và hạ tầng cơ sở. Giai đoạn thiết kế sẽ đưa ra kết quả là bản đặc tả chi tiết cho giai đoạn xây dựng hệ thống. 19 UML và các giai đoạn phát triển hệ thống Xây dựng (triển khai lập trình)  Các lớp của giai đoạn thiết kế sẽ được chuyển thành những dòng code trong một ngôn ngữ lập trình hướng đối tượng cụ thể (lưu ý không nên dùng ngôn ngữ lập trình hướng chức năng).  Đây có thể là một công việc khó khăn hay dễ dàng tùy theo khả năng của ngôn ngữ được lựa chọn.  Khi tạo ra các mô hình phân tích và thiết kế trong UML, tốt nhất nên tránh biến đổi ngay lập tức các mô hình này thành các dòng code.  Mô hình được sử dụng để dễ hiểu, dễ giao tiếp và tạo nên cấu trúc của hệ thống trong những giai đoạn trước. 20 UML và các giai đoạn phát triển hệ thống Kiểm thử Các nhóm sử dụng biểu đồ UML khác nhau làm nền tảng cho công việc của mình:  Kiểm thử đơn vị sử dụng biểu đồ lớp (class diagram) và đặc tả lớp,  kiểm thử tích hợp thường sử dụng biểu đồ thành phần (component diagram) và biểu đồ cộng tác (collaboration diagram), và  giai đoạn kiểm thử hệ thống sử dụng biểu đồ Use case (Use Case diagram) để đảm bảo hệ thống có phương thức hoạt động đúng như đã được định nghĩa từ ban đầu trong các biểu đồ này. 21 Các khái niệm cơ bản của UML  Hướng nhìn (view): Hướng nhìn chỉ ra những khía cạnh khác nhau của hệ thống cần phải được mô hình hóa. Một hướng nhìn không phải là một bản vẽ, mà là một sự trừu tượng hóa bao gồm một loạt các biểu đồ khác nhau  Biểu đồ (diagram): Biểu đồ là các hình vẽ miêu tả nội dung trong hướng nhìn. UML có tất cả 9 loại biểu đồ được sử dụng kết hợp để mô tả các hướng nhìn của hệ thống. 22 Các khái niệm cơ bản của UML  Phần tử mô hình (model element): Các khái niệm được sử dụng trong các biểu đồ được gọi là các phần tử mô hình, thể hiện các khái niệm hướng đối tượng quen thuộc.  Cơ chế chung: Cơ chế chung cấp thêm những lời nhận xét bổ sung, các thông tin cũng như các quy tắc ngữ pháp về một phần tử mô hình. Cơ chế chung còn có các cơ chế để có thể mở rộng ngôn ngữ UML 23 Các khái niệm cơ bản của UML Hướng nhìn  Một hệ thống cần phải được miêu tả với nhiều khía cạnh khác nhau: về mặt chức năng (cấu trúc tĩnh cũng như các tương tác động), về mặt phi chức năng (yêu cầu về thời gian, về độ đáng tin cậy, về quá trình thực thi) cũng như về khía cạnh tổ chức (tổ chức làm việc, quan hệ mô hình với dòng code). 24 Các khái niệm cơ bản của UML Hướng nhìn  Mỗi một hướng nhìn được miêu tả bằng nhiều biểu đồ, chứa đựng các thông tin nêu bật khía cạnh đặc biệt đó của hệ thống. Trong thực tế khi phân tích và thiết kế rất dễ xảy ra sự trùng lặp thông tin, cho nên một biểu đồ trên thật tế có thể là thành phần của nhiều hướng nhìn khác nhau. 25 Các khái niệm cơ bản của UML Hướng nhìn  Hướng nhìn Use case (Use Case view): đây là hướng nhìn chỉ ra khía cạnh chức năng của một hệ thống, nhìn từ hướng tác nhân bên ngoài.  Hướng nhìn Logic (logical view): chỉ ra chức năng sẽ được thiết kế bên trong hệ thống như thế nào, qua các khái niệm về cấu trúc tĩnh cũng như ứng xử động của hệ thống. 26 Các khái niệm cơ bản của UML Hướng nhìn  Hướng nhìn Thành phần (component view): chỉ ra khía cạnh tổ chức của các thành phần code.  Hướng nhìn Song song (concurrent view): chỉ ra sự tồn tại song song/ trùng hợp trong hệ thống, hướng đến vấn đề giao tiếp và đồng bộ hóa trong hệ thống.  Hướng nhìn Triển khai (deployment view): chỉ ra khía cạnh triển khai hệ thống 27 Các khái niệm cơ bản của UML 28 Các khái niệm cơ bản của UML 29 Hướng nhìn Use case (Use case View)  miêu tả chức năng của hệ thống sẽ phải cung cấp do được tác nhân từ bên ngoài mong đợi.  Tác nhân là thực thể tương tác với hệ thống; đó có thể là một người sử dụng hoặc là một hệ thống khác.  Biểu đồ Use case (Use Case diagram) và thỉnh thoảng cũng bao gồm cả các biểu đồ hoạt động (activity diagram). Các khái niệm cơ bản của UML 30 Hướng nhìn Use case (Use case View)  Mục tiêu của hệ thống là cung cấp các chức năng được miêu tả trong hướng nhìn này, cùng với một vài các thuộc tính mang tính phi chức năng.  Hướng nhìn Use case có ảnh hưởng đến tất cả các hướng nhìn khác.  Hướng nhìn này cũng được sử dụng để thẩm tra (verify) hệ thống trong kiểm thử, xem hệ thống có các chức năng yêu cầu.  Các khái niệm cơ bản của UML 31 Hướng nhìn Use case (Use case View)  Các khái niệm cơ bản của UML 32 Hướng nhìn logic (Logical View)  miêu tả phương thức mà các chức năng của hệ thống sẽ được cung cấp.  Nó được sử dụng chủ yếu cho các thiết kế viên và nhà phát triển.  Ngược lại với hướng nhìn Use case, hướng nhìn logic nhìn vào phía bên trong của hệ thống.  Các khái niệm cơ bản của UML 33  Cấu trúc tĩnh được miêu tả bằng các biểu đồ lớp (class diagram) và biểu đồ đối tượng (object diagram).  Quá trình mô hình động được miêu tả trong các biểu đồ trạng thái (state diagram), Biểu đồ trình tự (sequence diagram), biểu đồ tương tác (collaboration diagram) và biểu đồ hoạt động (activity diagram).   Các khái niệm cơ bản của UML 34 Hướng nhìn thành phần (Component View)  mô tả việc thực thi các module cũng như sự phụ thuộc giữa chúng với nhau. Nó thường được sử dụng cho nhà phát triển và bao gồm nhiều biểu đồ thành phần.  Thành phần ở đây là các module lệnh thuộc nhiều loại khác nhau, sẽ được chỉ ra trong biểu đồ cùng với cấu trúc cũng như sự phụ thuộc của chúng. Các khái niệm cơ bản của UML 35 Hướng nhìn song song (Concurrency View)  nhắm tới việc chia hệ thống thành các qui trình (process) và các bộ xử lý (processor).  Khía cạnh này vốn là một thuộc tính phi chức năng của hệ thống, cho phép ta sử dụng một cách hữu hiệu các nguồn tài nguyên, thực thi song song, cũng như xử lý các sự kiện không đồng bộ từ môi trường. Các khái niệm cơ bản của UML 36 Hướng nhìn triển khai (Deployment View)  Có các biểu đồ triển khai về mặt vật lý của hệ thống, ví dụ các máy tính, thiết bị và sự liên kết giữa chúng với nhau.  Hướng nhìn triển khai giành cho các nhà phát triển, người tích hợp cũng như người kiểm thử hệ thống và được thể hiện bằng các biểu đồ triển khai. Các khái niệm cơ bản của UML 37 Các khái niệm cơ bản của UML 38 Biểu đồ (Diagram)  là các hình vẽ bao gồm các ký hiệu phần tử mô hình hóa được sắp xếp để minh họa một thành phần cụ thể hay một khía cạnh cụ thể của hệ thống.  Một mô hình hệ thống thường có nhiều loại biểu đồ, mỗi loại có nhiều biểu đồ. Một biểu đồ là một thành phần của một hướng nhìn cụ thể; và khi được vẽ ra, nó thường thường cũng được xếp vào một hướng nhìn. Các khái niệm cơ bản của UML 39 Biểu đồ (Diagram) Các khái niệm cơ bản của UML 40 Biểu đồ (Diagram) Use Case được sử dụng trong quá trình tập hợp yêu cầu và phân tích yêu cầu để mô tả chức năng của hệ thống. Use Case xem các hành vi của hệ thống với góc nhìn từ bên ngoài hệ thống. Một Use Case mô tả chức năng của hệ thống với sự tham gia của tác nhân (actor). Một tác nhân thể hiện một thực thể tương tác với hệ thống. Các khái niệm cơ bản của UML 41 Biểu đồ (Diagram) Việc xác định các tác nhân và các Use Case sẽ định ra phạm vi của hệ thống: phân biệt các nhiệm vụ thực hiện bởi hệ thống và các nhiệm vụ thực hiện bởi môi trường. Các tác nhân đứng ở bên ngoài phạm vi của hệ thống, trong khi các Use Case nằm bên trong phạm vi của hệ thống. Các khái niệm cơ bản của UML 42 Biểu đồ (Diagram) Check Balance Card Holder Withdraw Cash Các khái niệm cơ bản của UML 43 Biểu đồ lớp (Class Diagrams) Các lớp là khái niệm trừu tượng về cấu trúc chung và hành vi của một tập hợp các đối tượng. Đối tượng là các trường hợp của các lớp được tạo ra, sửa đổi, và bị xóa trong quá trình thực hiện của hệ thống. Một đối tượng có trạng thái, bao gồm giá trị của các thuộc tính của nó và liên kết với các đối tượng khác. Các khái niệm cơ bản của UML 44 Biểu đồ lớp (Class Diagrams) Các khái niệm cơ bản của UML 45 Các lớp có thể quan hệ với nhau trong nhiều dạng thức: liên kết (associated - được kết nối với nhau), phụ thuộc (dependent - một lớp này phụ thuộc vào lớp khác), chuyên biệt hóa (specialized - một lớp này là một kết quả chuyên biệt hóa của lớp khác), hay đóng gói (packaged - hợp với nhau thành một đơn vị). Các khái niệm cơ bản của UML 46 Các khái niệm cơ bản của UML 47 Biểu đồ đối tượng  Một biểu đồ đối tượng (Object Diagram) là một phiên bản của biểu đồ lớp và thường cũng sử dụng các ký hiệu như biểu đồ lớp.  Sự khác biệt giữa hai loại biểu đồ này nằm ở chỗ biểu đồ đối tượng chỉ ra một loạt các đối tượng thực thể của lớp, thay vì các lớp. Một biểu đồ đối tượng vì vậy là một ví dụ của biểu đồ lớp Các khái niệm cơ bản của UML 48 Biểu đồ đối tượng Các khái niệm cơ bản của UML 49 Biểu đồ trạng thái (State Diagram)  Không được vẽ cho tất cả các lớp, mà chỉ riêng cho những lớp có một số lượng các trạng thái được định nghĩa rõ ràng và hành vi của lớp bị ảnh hưởng và thay đổi qua các trạng thái khác nhau.  Chỉ ra tất cả các trạng thái mà đối tượng của lớp này có thể có, và những sự kiện (event) nào sẽ gây ra sự thay đổi trạng. Các khái niệm cơ bản của UML 50 Biểu đồ trạng thái (State Diagram)  Một trạng thái đại diện cho một tập hợp các giá trị cho một đối tượng.  Một trạng thái có thể chuyển đổi sang một trạng thái khác khi có thỏa mãn một điều kiện nhất định.  Vòng tròn nhỏ màu đen là trạng thái ban đầu.  Một vòng tròn xung quanh một vòng tròn nhỏ màu đen là trạng thái cuối cùng. Các khái niệm cơ bản của UML 51 Biểu đồ trạng thái (State Diagram) White's turn Black's turn Black wins Draw White wins Start checkMate staleMate staleMate checkMate Chess game Các khái niệm cơ bản của UML 52  Biểu đồ hoạt động (Activity Diagrams)  Chỉ ra một trình tự lần lượt của các hoạt động.  Biểu đồ hoạt động thường được sử dụng để miêu tả các hoạt động được thực hiện trong một thủ tục, mặc dù nó cũng có thể được sử dụng để miêu tả các dòng chảy hoạt động khác, ví dụ như trong một Use case hay trong một trình tự tương tác. Các khái niệm cơ bản của UML 53 Biểu đồ hoạt động (Activity Diagrams)  Dòng điều khiển ở đây chạy giữa các