Minggu, 08 Desember 2019

Thread & Prosesnya



ALL ABOUT THREAD


       Thread adalah sebuah alur kontrol dari sebuah proses. Suatu proses yang multithreaded mengandung beberapa perbedaan alur kontrol dengan ruang alamat yang sama. Keuntungan dari multithreaded meliputi peningkatan respon dari user, pembagian sumber daya proses, ekonomis, dan kemampuan untuk mengambil keuntungan dari arsitektur multiprosesor. User level thread adalah thread yang tampak oleh programmer dan tidak diketahui oleh kernel. User level thread secara tipikal dikelola oleh sebuah library thread di ruang user. Kernel level thread didukung dan dikelola oleh kernel sistem operasi. Secara umum, user level thread lebih cepat dalam pembuatan dan pengelolaan dari pada kernel thread. Ada tiga perbedaan tipe dari model yang berhubungan dengan user dan kernel thread.
  • Model many to one: memetakan beberapa user level thread hanya ke satu buah kernel thread.
  • Model one to one: memetakan setiap user thread ke dalam satu kernel thread. Berakhir.
  • Model many to many: mengizinkan pengembang untuk membuat user thread sebanyak mungkin, konkurensi tidak dapat tercapai karena hanya satu thread yang dapat dijadualkan oleh kernel dalam satu waktu.



Multithreaded Process





Benefits/manfaat

  •  Kemampuan reaksi
  •  Sumber daya berbagi
  •  Ekonomi
  •  Scalabilas
   Thread bermanfaat untuk Multithreading yang berguna untuk Multiprocessor dan Singleprocessor. Kegunaan untuk system Multiprocessor, adalah :
             a) Sebagai unit pararel atau tingkat granularitas pararelisme.
             b) Peningkatan kinerja disbanding berbasis proses.
 
Kegunaan Multithreading pada singleprocessor, adalah :

             a) Kerja foreground dan background sekaligus di satu aplikasi.
             b) Penanganan asynchronous processing menjadi lebih baik.
             c) Mempercepat eksekusi program.
             d) Pengorganisasian program menjadi lebih baik.


Kegunaan Thread

Multithreading berguna untuk multiprocessor dan singleprocessor.

Kegunaan untuk system multiprocessor adalah :

  • Sebagai unit pararel atau tingkat granularitas pararelisme.
  • Peningkatan kinerja disbanding berbasis proses.

Karakteristik Thread

         Proses merupakan lingkungan eksekusi bagi thread-thread yang dimilikinya. Thread-thread di satu proses memakai bersama sumber daya yang dimiliki proses, yaitu :
  • Ruang alamat.
  • Himpunan berkas yang dibuka.
  • Proses-proses anak.
  • Timer-timer.
  • Snyal-sinyal.
  • Sumber daya-sumber daya lain milik proses.

Implementasi Paket Thread
 
1. Thread level kernel.
   > Keunggulan :
      · Memudahkan koordinasi multithread seperti proses server.
      · Tidak seboros kumpulan proses tradisional.

  > Kelemahan :
     · Operasi manajemen thread sangat lebih boros.
     · Kernel harus menyediakan semua feature.

2. Thread level pemakai.

   > Keunggulan :
      Kinerja luar biasa bagus disbanding thread level kernel.
      · Tidak diperlukan modifikasi kernel.
      · Fleksibelitas tinggi.

   > Kelemahan :
      · Tidak manfaatkan multiprocessor.
      · Untuk aplikasi dengan keterlibatan kernel yang kecil.
      · Mengharuskan nonblocking system call.


Status Thread:

Suatu thread bisa berada pada salah satu dari status berikut:


New :
Thread yang berada di status ini adalah objek dari kelas Thread yang baru dibuat, yaitu saat instansiasi objek dengan statement new. Saat thread berada di status new, belum ada sumber daya yang dialokasikan, sehingga thread belum bisa menjalankan perintah apapun.
Runnable:
Agar thread bisa menjalankan tugasnya, method start() dari kelas Thread harus dipanggil. Ada dua hal yang terjadi saat pemanggilan method start(), yaitu alokasi memori untuk thread yang dibuat dan pemanggilan method run(). Saat method run() dipanggil, status thread berubah menjadi runnable, artinya thread tersebut sudah memenuhi syarat untuk dijalankan oleh JVM. Thread yang sedang berjalan juga berada di status runnable.
Blocked :
Sebuah thread dikatakan berstatus blocked atau terhalang jika terjadi blocking statement, misalnya pemanggilan method sleep()sleep() adalah suatu method yang menerima argumen bertipe integer dalam bentuk milisekon. Argumen tersebut menunjukkan seberapa lama thread akan "tidur". Selain sleep(), dulunya dikenal method suspend(), tetapi sudah disarankan untuk tidak digunakan lagi karena mengakibatkan terjadinya deadlock. Di samping blocking statement, adanya interupsi M/K juga dapat menyebabkan thread menjadi blockedThread akan menjadi runnable kembali jika interval method sleep()-nya sudah berakhir, atau pemanggilan method resume() jika untuk menghalangi thread tadi digunakan method suspend() atau M/K sudah tersedia lagi.
Dead : 
Sebuah thread berada di status dead bila telah keluar dari method run(). Hal ini bisa terjadi karena thread tersebut memang telah menyelesaikan pekerjaannya di method run(), maupun karena adanya pembatalan thread. Status jelas dari sebuah thread tidak dapat diketahui, tetapi method isAlive() mengembalikan nilai boolean untuk mengetahui apakah thread tersebut dead atau tidak.

Tidak ada komentar:

Posting Komentar