Escolar Documentos
Profissional Documentos
Cultura Documentos
vutienthai@gmail.com
1
Multithreading
• Đa nhiệm và đa tuyến
• Tạo lập và sử dụng tuyến
• Lớp Thread
• Giao tiếp Runnable
• Đồng bộ hoá các tuyến
• Tuyến ma
• Nhóm tuyến
2
Đa nhiệm (multitasking)
3
Đa nhiệm (multitasking)
Task 1
Task 2
Task 3
4
Đa nhiệm (multitasking)
5
Tuyến và đa tuyến
• Tuyến là mạch thi hành độc lập của một tác
vụ trong chương trình.
• Một chương trình có nhiều tuyến thực hiện
cùng lúc gọi là đa tuyến.
program program
6
Tạo tuyến
7
Cách 1: Kế thừa từ Thread
Tạo lớp MyThread kế
thừa từ Thread và nạp class MyThread extends Thread {
chồng phương thức ….
run() của lớp Thread.
public void run() {
…
}
}
8
Cách 1: Kế thừa từ Thread
9
Tạo tuyến
Tạo tuyến mới
10
Cách 2: Cài đặt Runnable
Trong trường hợp lớp đã
class MyClass extends SomeClass
kế thừa từ một lớp khác,
cần cài đặt giao tiếp
implements Runnable {
Runnable để lớp có thể là ….
một tuyến. public void run() {
…
Runnable có duy nhất
}
một phương thức run().
}
11
Độ ưu tiên
12
Bộ lập lịch
13
Bộ lập lịch
Priority 10 A B
Ví dụ: Tuyến A và B sẽ
luân phiên nhau thực thi Priority 9 C
cho đến khi kết thúc. Tiếp
theo tuyến C sẽ thực thi Priority 8
đến khi kết thúc. Tiếp theo
tuyến D, E và F sẽ luân Priority 7 D E F
phiên thực thi đến khi kết
thúc. Tiếp theo tuyến G Priority 6 G
thực thi đến khi kết thúc.
Cuối cùng tuyến H và I Priority 5
luân phiên thực thi đến khi
Priority 4
kết thúc.
Nhận xét: Các tuyến có độ Priority 3
ưu tiên thấp sẽ có nguy cơ Priority 2 H I
bị trì hoãn vô hạn định.
Priority 1
14
Ví dụ về đa tuyến
15
Ví dụ về đa tuyến
16
Ví dụ về đa tuyến
// method run is the code to be executed by new thread
public void run()
{
try {
System.out.println( getName() + " starts to sleep");
Thread.sleep( sleepTime );
} // sleep() may throw an InterruptedException
catch ( InterruptedException e) {
e.printStackTrace();
}
System.out.println( getName() + " done sleeping" );
}
}
17
Ví dụ về đa tuyến
public class ThreadTest
{
public static void main( String [ ] args )
{
PrintThread thread1 = new PrintThread( "thread1" );
PrintThread thread2 = new PrintThread( "thread2" );
PrintThread thread3 = new PrintThread( "thread3" );
System.out.println( "Starting threads" );
19
Một số phương thức của Thread
20
Vòng đời của tuyến
born
start
read y
q uantum
exp iratio n d isp atch
yield (a ssig n a
inte rrup t p roce ssor)
running
slee p inte
rval
expires
21
Đồng bộ hoá tuyến
• Việc các tuyến trong chương trình cùng truy
nhập vào một đối tượng có thể sẽ đem lại kết
quả không như mong muốn. Ví dụ: Tuyến A
cập nhật đối tượng X và tuyến B đọc dữ liệu
từ X. Rất có thể xảy ra sự cố là tuyến B đọc
dữ liệu chưa được cập nhật.
• Đồng bộ hoá tuyến (thread synchronization)
giúp cho tại mỗi thời điểm chỉ có một tuyến
có thể truy nhập vào đối tượng còn các tuyến
khác phải đợi. Ví dụ: Trong khi tuyến A cập
nhật X thì tuyến B chưa được đọc.
22
Đồng bộ hoá tuyến
đọc ghi
Consumer buffer Producer
25
Quan hệ Producer-Consumer
26
Ví dụ về P-C: Không đồng bộ
class Buffer
{
private int buffer = -1;
27
Ví dụ về P-C: Không đồng bộ
28
Ví dụ về P-C: Không đồng bộ
public void run()
{
for ( int count = 1; count <= 5; count++ )
{
try {
Thread.sleep( ( int ) ( Math.random() * 3000 ) );
sharedBuffer.set( count );
System.out.println( "Producer writes " + count);
} catch ( InterruptedException e ) {
e.printStackTrace();
}
}
System.out.println( getName() + " finished.");
}
}
29
Ví dụ về P-C: Không đồng bộ
30
Ví dụ về P-C: Không đồng bộ
public void run()
{
for ( int count = 1; count <= 5; count++ )
{
try {
Thread.sleep( ( int ) ( Math.random() * 3000 ) );
System.out.println( "Consumer reads " +
sharedBuffer.get());
} catch ( InterruptedException e ) {
e.printStackTrace();
}
}
System.out.println( getName() + " finished.");
}
}
31
Ví dụ về P-C: Không đồng bộ
public class SharedBufferTest1
{
public static void main( String [] args )
{
// create shared object used by threads
Buffer sharedBuffer = new Buffer();
32
Kết quả khi không đồng bộ
Producer writes 1
Producer writes 2
Consumer reads 2
Producer writes 3
Producer writes 4
Consumer reads 4
Producer writes 5
Producer finished.
Consumer reads 5
Consumer reads 5
Consumer reads 5
Consumer finished.
33
Ví dụ về P-C: Có đồng bộ
class Buffer// Thiết kế lại lớp Buffer
{
private int buffer = -1;
private boolean writable = true; public
synchronized void set( int value ) {
while ( ! writable ) {
try {
wait();
} catch ( InterruptedException e ) {
e.printStackTrace();
}
}
buffer = value;
writable = false;
notify(); 34
}
Ví dụ về P-C: Có đồng bộ
public synchronized int get()
{
while ( writable ) {
try {
wait();
} catch ( InterruptedException e ) {
e.printStackTrace();
}
}
writable = true;
notify();
return buffer;
}
}
35
Kết quả khi có đồng bộ
Producer writes 1
Consumer reads 1
Producer writes 2
Consumer reads 2
Producer writes 3
Consumer reads 3
Producer writes 4
Consumer reads 4
Producer writes 5
Producer finished.
Consumer reads 5
Consumer finished.
36
Tuyến ma (daemon thread)
37
Nhóm tuyến (thread group)
38