Java Concurrency - Kunci Antarmuka
Antarmuka java.util.concurrent.locks.Lock digunakan sebagai mekanisme sinkronisasi utas yang mirip dengan blok tersinkronisasi. Mekanisme Penguncian baru lebih fleksibel dan memberikan lebih banyak opsi daripada blok tersinkronisasi. Perbedaan utama antara Kunci dan blok tersinkronisasi adalah sebagai berikut:
Guarantee of sequence- Blok tersinkronisasi tidak memberikan jaminan urutan apa pun di mana thread yang menunggu akan diberi akses. Antarmuka kunci menanganinya.
No timeout- Blok tersinkronisasi tidak memiliki opsi batas waktu jika kunci tidak diberikan. Antarmuka kunci menyediakan opsi seperti itu.
Single method - Blok tersinkronisasi harus sepenuhnya terkandung dalam satu metode sedangkan metode antarmuka kunci lock () dan unlock () dapat dipanggil dalam metode yang berbeda.
Metode Kunci
Berikut adalah daftar metode penting yang tersedia di kelas Lock.
Sr.No. | Metode & Deskripsi |
---|---|
1 | public void lock() Akuisisi kunci. |
2 | public void lockInterruptibly() Memperoleh kunci kecuali utas saat ini terputus. |
3 | public Condition newCondition() Mengembalikan contoh Kondisi baru yang terikat ke contoh Lock ini. |
4 | public boolean tryLock() Memperoleh kunci hanya jika gratis pada saat pemanggilan. |
5 | public boolean tryLock() Memperoleh kunci hanya jika gratis pada saat pemanggilan. |
6 | public boolean tryLock(long time, TimeUnit unit) Memperoleh kunci jika kosong dalam waktu tunggu yang ditentukan dan utas saat ini belum terputus. |
7 | public void unlock() Lepaskan kunci. |
Contoh
Program TestThread berikut mendemonstrasikan beberapa metode antarmuka Lock ini. Di sini kami telah menggunakan lock () untuk mendapatkan kunci dan buka kunci () untuk membuka kunci.
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
class PrintDemo {
private final Lock queueLock = new ReentrantLock();
public void print() {
queueLock.lock();
try {
Long duration = (long) (Math.random() * 10000);
System.out.println(Thread.currentThread().getName()
+ " Time Taken " + (duration / 1000) + " seconds.");
Thread.sleep(duration);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.printf(
"%s printed the document successfully.\n", Thread.currentThread().getName());
queueLock.unlock();
}
}
}
class ThreadDemo extends Thread {
PrintDemo printDemo;
ThreadDemo(String name, PrintDemo printDemo) {
super(name);
this.printDemo = printDemo;
}
@Override
public void run() {
System.out.printf(
"%s starts printing a document\n", Thread.currentThread().getName());
printDemo.print();
}
}
public class TestThread {
public static void main(String args[]) {
PrintDemo PD = new PrintDemo();
ThreadDemo t1 = new ThreadDemo("Thread - 1 ", PD);
ThreadDemo t2 = new ThreadDemo("Thread - 2 ", PD);
ThreadDemo t3 = new ThreadDemo("Thread - 3 ", PD);
ThreadDemo t4 = new ThreadDemo("Thread - 4 ", PD);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
Ini akan menghasilkan hasil sebagai berikut.
Keluaran
Thread - 1 starts printing a document
Thread - 4 starts printing a document
Thread - 3 starts printing a document
Thread - 2 starts printing a document
Thread - 1 Time Taken 4 seconds.
Thread - 1 printed the document successfully.
Thread - 4 Time Taken 3 seconds.
Thread - 4 printed the document successfully.
Thread - 3 Time Taken 5 seconds.
Thread - 3 printed the document successfully.
Thread - 2 Time Taken 4 seconds.
Thread - 2 printed the document successfully.
Kami telah menggunakan kelas ReentrantLock sebagai implementasi antarmuka Lock di sini. Kelas ReentrantLock memungkinkan utas mengunci metode meskipun sudah memiliki kunci di metode lain.