Sự khác biệt giữa tiến trình và luồng

1. Tiến trình (process) là gì?

Tiến trình là một chương trình đang hoạt động, tức là một chương trình đang được thực thi. Tiến trình không chỉ là code chương trình vì nó bao gồm program counter (bộ đếm chương trình), process stack, register, code chương trình, v.v... So với những điều này, code chương trình chỉ là phần văn bản.

2. Luồng (thread) là gì?

Luồng là một tiến trình gọn nhẹ có thể được quản lý độc lập bởi một bộ lập lịch. Nó cải thiện hiệu suất ứng dụng bằng cách sử dụng phương pháp xử lý song song. Một luồng chia sẻ thông tin như data segment (phân đoạn dữ liệu), code segment (phân đoạn code), file, v.v... với các luồng ngang hàng, đồng thời nó cũng chứa các register, ngăn xếp, bộ đếm của chính nó, v.v...

Luồng là các phần của một tiến trình
Luồng là các phần của một tiến trình

3. Sự khác biệt giữa tiến trình và luồng

Sự khác biệt chính giữa tiến trình và luồng được trình bày trong bảng sau:

Tiêu chíTiến trìnhLuồng
Định nghĩaTiến trình là một chương trình đang được thực thi, tức là một chương trình đang hoạt động.Luồng là một tiến trình gọn nhẹ có thể được quản lý độc lập bởi một bộ lập lịch.
Thời gian chuyển đổi ngữ cảnhCác tiến trình đòi hỏi nhiều thời gian hơn để chuyển đổi ngữ cảnh vì chúng nặng hơn.Các luồng yêu cầu ít thời gian hơn để chuyển đổi ngữ cảnh vì chúng nhẹ hơn tiến trình.
Chia sẻ bộ nhớCác tiến trình hoàn toàn độc lập và không chia sẻ bộ nhớ.Một luồng có thể chia sẻ một số bộ nhớ với các luồng ngang hàng của nó.
Giao tiếpGiao tiếp giữa các tiến trình đòi hỏi nhiều thời gian hơn giữa các luồng.Giao tiếp giữa các luồng yêu cầu ít thời gian hơn giữa các quá trình.
Khi bị chặnNếu một tiến trình bị chặn, các tiến trình còn lại có thể tiếp tục thực thi.Nếu một luồng cấp người dùng bị chặn, tất cả các luồng ngang hàng của nó cũng bị chặn.
Tiêu thụ tài nguyênTiến trình yêu cầu nhiều tài nguyên hơn luồng.Luồng thường cần ít tài nguyên hơn các tiến trình.
Sự phụ thuộcCác tiến trình riêng lẻ độc lập với nhau.Luồng là các phần của một tiến trình và do đó chúng mang tính phụ thuộc.
Chia sẻ dữ liệu và codeCác tiến trình có dữ liệu và code segment độc lập.Một luồng chia sẻ data segment, code segment, file, v.v... với các luồng ngang hàng
Cách hệ điều hành nhìn nhậnTất cả các tiến trình khác nhau được hệ điều hành xử lý riêng biệt.Tất cả các luồng ngang hàng cấp người dùng được hệ điều hành coi như một tác vụ duy nhất.
Thời gian tạoCác tiến trình đòi hỏi nhiều thời gian hơn để tạo.Các luồng yêu cầu ít thời gian hơn để tạo.
Thời gian chấm dứtCác tiến trình yêu cầu nhiều thời gian hơn để chấm dứt.Luồng yêu cầu ít thời gian hơn để kết thúc.
Chủ Nhật, 28/03/2021 09:15
51 👨 9.821
0 Bình luận
Sắp xếp theo
    ❖ Kiến thức cơ bản