Sơ đồ UML là gì? Các loại sơ đồ UML phổ biến nhất 2024

Sơ đồ UML là gì? Các loại sơ đồ UML phổ biến nhất 2024

21/05/2024

673

0

Chia sẻ lên Facebook
Sơ đồ UML là gì? Các loại sơ đồ UML phổ biến nhất 2024

Sơ đồ UML là gì? Hãy tưởng tượng bạn đang xây dựng một ngôi nhà. Để mọi người hiểu được ngôi nhà sẽ trông như thế nào, bạn cần một bản vẽ chi tiết bao gồm: các thành phần chính, nội thất,... Sơ đồ UML cũng tương tự như vậy, nhưng nó là bản vẽ dành cho “phần mềm”. Để tìm hiểu thêm về các loại sơ đồ UML phổ biến, lợi ích và một số công cụ hỗ trợ, hãy tham khảo bài viết dưới đây của Topchuyengia

 

Nếu bạn muốn nâng cao kỹ năng thiết kế phần mềm của mình với Sơ đồ UML? Hãy booking tư vấn ngay với các chuyên gia BA của chúng tôi trên app Askany. 

Sơ đồ UML là gì?

Theo Wiki, ngôn ngữ mô hình hóa thống nhất (Unified Modeling Language: UML) là một ngôn ngữ mô hình gồm các ký hiệu đồ họa được sử dụng trong lập trình hướng đối tượng để mô hình hóa hệ thống thông tin một cách nhanh chóng và hiệu quả. UML cung cấp một cách thức mô tả hệ thống thông tin cả về cấu trúc lẫn hoạt động, giúp các nhà thiết kế, lập trình viên và người dùng hệ thống có được cái nhìn tổng quan và đầy đủ về hệ thống.

sơ đồ UML
Hình vẽ sơ đồ UML

Sơ đồ UML (UML diagrams) bao gồm một loạt các sơ đồ được sử dụng để biểu diễn cấu trúc và hành vi của hệ thống như sau:

  • Sơ đồ Lớp (Class Diagram): Biểu diễn cấu trúc của hệ thống qua các lớp và mối quan hệ giữa chúng.
  • Sơ đồ Đối tượng (Object Diagram): Mô tả các thực thể và mối liên kết giữa chúng trong một thời điểm cụ thể.
  • Sơ đồ Tình huống Sử dụng (Use Cases Diagram): Chỉ ra các chức năng của hệ thống và tương tác của người dùng.
  • Sơ đồ Trình tự (Sequence Diagram): Mô tả trình tự của các sự kiện giữa các đối tượng.
  • Sơ đồ Cộng tác (Composite Structure): Biểu diễn cách thức các phần của hệ thống làm việc cùng nhau.
  • Sơ đồ Trạng thái (State Machine Diagram): Thể hiện các trạng thái khác nhau của đối tượng và chuyển đổi giữa chúng.
  • Sơ đồ Thành phần (Component Diagram): Định rõ cấu trúc và phụ thuộc giữa các thành phần.
  • Sơ đồ Hoạt động (Activity Diagram): Biểu diễn luồng điều khiển và luồng dữ liệu trong hệ thống.
  • Sơ đồ Triển khai (Deployment Diagram): Mô tả cách thức phân phối các thành phần hệ thống trên phần cứng.
  • Sơ đồ Gói (Package Diagram): Nhóm các lớp liên quan vào một gói.
  • Sơ đồ Liên lạc (Communication Diagram): Mô tả tương tác giữa các đối tượng dựa trên thông điệp.
  • Sơ đồ Tương tác (Interaction Overview Diagram – UML 2.0): Tổng quan về luồng tương tác trong hệ thống (UML 2.0).
  • Sơ đồ Phối hợp Thời gian (Timing Diagram – UML 2.0): Biểu diễn thời gian và sự kiện cho các tương tác (UML 2.0).

Lợi ích của việc sử dụng sơ đồ UML

  • Nắm bắt trọn vẹn các yêu cầu của người dùng: UML giúp các nhà thiết kế hệ thống có thể dễ dàng phân tích yêu cầu của người dùng và thiết kế hệ thống đáp ứng đầy đủ các yêu cầu đó.

  • Tăng hiệu quả thiết kế và phát triển hệ thống: UML giúp tăng hiệu quả của quá trình thiết kế và phát triển hệ thống bằng cách cung cấp một ngôn ngữ chung cho tất cả các bên liên quan.

  • Cải thiện khả năng bảo trì hệ thống: UML giúp cải thiện khả năng bảo trì hệ thống bằng cách cung cấp tài liệu mô tả chi tiết về cấu trúc và hoạt động của hệ thống.

  • Tăng khả năng tái sử dụng: UML giúp tăng khả năng tái sử dụng các thành phần hệ thống bằng cách cung cấp một cách thức mô tả các thành phần đó một cách thống nhất.

Xem thêm: Root cause là gì? Giải đáp những thắc mắc của bạn về Root cause.
 

Ứng dụng của UML

UML được sử dụng rộng rãi trong lập trình hướng đối tượng để thiết kế và phát triển các hệ thống thông tin trong nhiều lĩnh vực khác nhau, bao gồm:

  • Phần mềm doanh nghiệp: UML được sử dụng để thiết kế và phát triển các hệ thống phần mềm doanh nghiệp, chẳng hạn như hệ thống quản lý quan hệ khách hàng (CRM), hệ thống quản lý chuỗi cung ứng (SCM) và hệ thống quản lý tài chính (ERP).

  • Phần mềm web: UML được sử dụng để thiết kế và phát triển các ứng dụng web, chẳng hạn như trang web thương mại điện tử, mạng xã hội và ứng dụng web di động.

  • Hệ thống nhúng: UML được sử dụng để thiết kế và phát triển các hệ thống nhúng, chẳng hạn như hệ thống điều khiển tự động, hệ thống y tế và hệ thống thông tin giải trí.

Các loại sơ đồ UML phổ biến nhất

Dưới đây là 3 loại biểu đồ UML phổ biến thường dùng trong thực tế mà bạn nên tìm hiểu kỹ.

Use Case Diagram

Biểu đồ tác nhân - sử dụng Use case là loại phổ biến nhất trong sơ đồ UML. Nó là một công cụ giúp hiển thị các chức năng mà hệ thống cần cung cấp và cách các tác nhân bên ngoài tương tác với những chức năng đó.

Mỗi tác nhân đại diện cho một người dùng hoặc một hệ thống khác. Chúng có thể tương tác với hệ thống của bạn. Mỗi Use case là một quy trình hoặc một dịch vụ cụ thể mà hệ thống thực hiện. Sơ đồ này thường không đi sâu vào chi tiết cách thức hoạt động bên trong của một hệ thống, mà nó chỉ tập trung vào việc mô tả hành vi của hệ thống từ góc nhìn của người dùng.

Các thành phần chính của sơ đồ bao gồm: tác nhân (Actor), chức năng tương tác (Use Case), và mối quan hệ (Relationship) giữa chúng.

Thành phần Actor được ký hiệu như sau:

sơ đồ UML

Hay:

sơ đồ UML


Thành phần Use case được kí hiệu bằng hình elips.

sơ đồ UML


Thành phần mối quan hệ giữa các use case được thể hiện như sau:

  • Association: dùng để mô tả mối quan hệ giữa Actor & Use Case và giữa các Use Case với nhau

sơ đồ UML

  • Include: biểu thị mối quan hệ giữa các Use Case với nhau. Include mô tả việc một Use Case lớn được chia thành các Use Case nhỏ để dễ dàng cài đặt (module hóa) hoặc thể hiện sự dùng lại.

sơ đồ UML

  • Extend: biểu thị quan hệ giữa 2 Use Case. Quan hệ Extend được dùng khi có một Use Case được tạo ra mục đích để bổ sung chức năng cho một Use Case có sẵn. Và chúng được sử dụng trong một điều kiện nhất định nào đó.

sơ đồ UML

  • Generalization: sử dụng để thể hiện quan hệ thừa kế giữa các Actor hoặc giữa các Use Case với nhau.

sơ đồ UML

Ví dụ về cách sử dụng Use Case Diagram trong thực tế:

 

Ở ví dụ này, Topchuyengia sẽ xây dựng một phần mềm quản lý thư viện sách cho club FCT có tên Library Management FCT. Ứng dụng của phần mềm này là giúp nhân sự có thể quản lý danh mục sách đang có trong thư viện. Để bắt đầu xây dựng phần mềm, chúng ta sẽ giả định những yêu cầu của người dùng đối với phần mềm như sau:

  • Chức năng chính của phần mềm này là quản lý danh mục sách đang có trong thư viện.
  • Phần mềm cho phép mentor, học sinh của club đăng ký tài khoản với mục đích mượn hoặc trả sách.
  • Đối với mỗi đầu sách, phần mềm sẽ phải lưu giữ thông tin về tên sách, tác giả, năm xuất bản.


Sau khi thu thập đầy đủ những yêu cầu về tính năng của phần mềm, chúng ta sẽ tiến hàng thiết kế Use case diagram để có cái nhìn tổng quan về tính năng của phần mềm. Ở đây, đối tượng sử dụng phần mềm chính là các học sinh và mentor được gọi chung là user. Và nó được ký hiệu bằng Actor của Use case diagram. Tiếp theo, các action mà user thực hiện trên phần mềm sẽ bao gồm: đăng nhập (login), đăng xuất (logout),  đăng ký tài khoản (register), mượn sách (borrow) và trả sách (give back). Kết quả chúng ta sẽ có một Use case diagram đơn giản như sau:

sơ đồ UML

Class Diagram

Biểu đồ lớp Class diagram dùng để mô tả kiểu của các đối tượng trong hệ thống và các loại quan hệ khác nhau tồn tại giữa chúng. Thành phần chính của một class diagram bao gồm:

  • Tên class
  • Attribute (thuộc tính, field, property)
  • Operation (phương thức, method, function)


Ví dụ khai báo tên, operation, attribute kèm theo kiểu trả về của 1 class như sau:

sơ đồ UML

Ngoài ra, để thể hiện thêm phạm vi truy cập cho các thuộc tính và phương thức trong class, bạn có thể sử dụng thêm các ký hiệu như sau:

  • Private ( – ): Chỉnh các đối tượng được tạo trong class này mới có thể sử dụng.
  • Public ( + ):  Tất cả đối tượng đều có thể sử dụng.
  • Protected ( # ): Chỉ những đối tượng được tạo từ class này và class kế thừa từ class này mới có thể sử dụng.

sơ đồ UML

Thành phần Relationship trong Biểu đồ Lớp có thể được chia thành 4 loại như sau:

sơ đồ UML

  • Composition: Đối tượng tạo từ class A mất thì đối tượng tạo từ class B cũng sẽ mất.
  • Inheritance: Có 1 class kế thừa từ 1 class khác.
  • Association: Có 2 class liên hệ với nhau nhưng không chỉ rõ mối liên hệ.
  • Aggregation: Đối tượng tạo từ class A mất thì đối tượng tạo từ class B vẫn tồn tại độc lập.

Trong sơ đồ lớp, “Bội số quan hệ” chỉ số lượng đối tượng của một lớp có thể liên kết với đối tượng của lớp khác. Mỗi liên kết giữa hai lớp có hai bội số quan hệ, mỗi bội số đặt ở một đầu của liên kết, thể hiện mối quan hệ như sau:

  • 0…1: Không hoặc một đối tượng.
  • n: Chính xác n đối tượng.
  • 0…*: Không hoặc nhiều đối tượng.
  • 1…*: Ít nhất một đối tượng.
  • m…n: Ít nhất m đối tượng nhưng không quá n đối tượng.

 

Ví dụ sử dụng Class Diagram:
 

Topchuyengia sẽ tiếp tục ví dụ về việc xây dựng sơ đồ lớp cho hệ thống quản lý thư viện FCT. Sau khi đã có sơ đồ tác nhân-sử dụng Use case Diagram, chúng ta sẽ phát triển sơ đồ Class Diagram.

 

Phần mềm sẽ bao gồm các class chính là: Quản lý thư viện - Library Management FCT, Người dùng (user), tài khoản (account), sách (book). Các thuộc tính và phương thức của mỗi lớp sẽ được thiết kế dựa trên yêu cầu cụ thể và mục tiêu của hệ thống..

sơ đồ UML

Sequence Diagram

Sơ đồ tuần tự - Sequence Diagram là một công cụ mô hình hóa dùng để mô tả quy trình giao tiếp giữa các đối tượng trong một kịch bản cụ thể, theo thứ tự thời gian. Nó giúp ta hiểu rõ cách thức và thời điểm các đối tượng trao đổi thông tin.

 

Dưới đây là các yếu tố cấu thành nên sơ đồ tuần tự:

  • Đối tượng (object or class): Được biểu thị qua hình chữ nhật, đại diện cho một đối tượng hoặc lớp.

sơ đồ UML

  • Lifelines: Đường thẳng đứng xuất phát từ mỗi đối tượng, biểu thị vòng đời của nó.

sơ đồ UML

  • Thông điệp (Message):  Các mũi tên biểu thị thông điệp được gửi giữa các đối tượng.

sơ đồ UML

  • Hoạt động: Các hình chữ nhật nhỏ liền kề với đường đời, biểu thị quá trình xử lý nội bộ.

sơ đồ UML

Ví dụ cách sử dụng Sequence Diagram:

 

Vẫn tiếp tục áp dụng sơ đồ tuần tự cho hệ thống quản lý thư viện FCT. Ở đây chúng ta sẽ sử dụng Sequence diagram để mô tả lại quy trình action mượn sách của người dùng. Để một user mượn sách thành công thì họ cần thực hiện yêu cầu mượn sách, hệ thống sẽ kiểm tra tình trạng sẵn có của sách và kiểm tra trạng thái xem người dùng có đủ điều kiện mượn sách hay không. Cuối cùng sẽ trả về thông báo cho người dùng biết là có thể mượn sách tại thư viện hay không.

sơ đồ UML

Tổng hợp công cụ vẽ sơ đồ UML

sơ đồ uml
Diagram Design là một trong các công cụ vẽ UML nổi tiếng hiện nay

 

Công cụ Offline:

http://diagram-designer.en.softonic.com/

 

Công cụ Online:
https://app.diagrams.net/
https://cacoo.com/diagrams/

 

Ngoài ra, còn có một số công cụ vẽ sơ đồ UML phổ biến và dễ sử dụng mà bạn có thể tham khảo:

  1. Lucidchart: Một công cụ trực tuyến cho phép bạn tạo các loại sơ đồ UML, bao gồm cả sơ đồ cấu trúc và hành vi.
  2. Astah: Một công cụ mô hình hóa đồ họa giành giải thưởng, hỗ trợ tạo sơ đồ UML nhanh chóng và dễ dàng cho cá nhân và nhóm.
  3. Visual Paradigm: Một công cụ UML trực tuyến với các tính năng mạnh mẽ, kiểm tra cú pháp UML ngay lập tức và giao diện người dùng dễ sử dụng.

Bạn có thể chọn công cụ phù hợp với nhu cầu và sở thích của mình để bắt đầu tạo các sơ đồ UML cho dự án của bạn.

 

Đó là toàn bộ thông tin trả lời cho câu hỏi “Sơ đồ UML là gì” bao gồm: khái niệm, các loại sơ đồ phổ biến nhất, lợi ích và một số công cụ vẽ biểu đồ UML. Tuy nhiên, khi bắt tay vào vẽ, BA đôi lúc sẽ cảm thấy bối rối vì có quá nhiều loại sơ đồ UML khác nhau, không biết chọn loại nào, hoặc khi thay đổi thông tin trên sơ đồ này có thể ảnh hưởng đến các sơ đồ khác. Nếu bạn cũng đang gặp tình huống tương tự, hãy gửi câu hỏi và tình huống cụ thể của bạn về cho chuyên gia trên Askany. Chúng tôi sẽ tư vấn và hỗ trợ bạn trong thời gian sớm nhất.

Click lấy PASS
Tôi là Tô Lãm với hơn 4 năm kinh nghiệm trong lĩnh vực IT, Business Analyst, Data Analyst, Tracking,... cho rất nhiều doanh nghiệp SME. Tôi tốt nghiệp trường Công nghệ Thông tin cùng với kỹ năng và kiến thức trau dồi của mình, tôi mong muốn được chia sẻ các thông tin hữu ích dến với người đọc thông qua các bài viết trên Topchuyengia, mọi người hãy follow mình nhé.

Kinh nghiệm thực tế

Tư vấn 1:1

Uy tín

Đây là 3 tiêu chí mà TOPCHUYENGIA luôn muốn hướng tới để đem lại những thông tin hữu ích cho cộng đồng