Arsitektur Berorientasi Interaksi

Tujuan utama dari arsitektur berorientasi interaksi adalah untuk memisahkan interaksi pengguna dari abstraksi data dan pemrosesan data bisnis. Arsitektur perangkat lunak yang berorientasi interaksi menguraikan sistem menjadi tiga partisi utama -

  • Data module - Modul data menyediakan abstraksi data dan semua logika bisnis.

  • Control module - Modul kontrol mengidentifikasi aliran tindakan kontrol dan konfigurasi sistem.

  • View presentation module - Modul tampilan presentasi bertanggung jawab atas presentasi visual atau audio dari keluaran data dan juga menyediakan antarmuka untuk masukan pengguna.

Arsitektur berorientasi interaksi memiliki dua gaya utama - Model-View-Controller (MVC) dan Presentation-Abstraction-Control(PAC). Baik MVC dan PAC mengusulkan tiga dekomposisi komponen dan digunakan untuk aplikasi interaktif seperti aplikasi web dengan banyak pembicaraan dan interaksi pengguna. Mereka berbeda dalam aliran kontrol dan organisasi mereka. PAC adalah arsitektur hierarki berbasis agen tetapi MVC tidak memiliki struktur hierarki yang jelas.

Model-View-Controller (MVC)

MVC menguraikan aplikasi perangkat lunak yang diberikan menjadi tiga bagian yang saling berhubungan yang membantu dalam memisahkan representasi internal informasi dari informasi yang disajikan atau diterima dari pengguna.

Modul Fungsi
Model Enkapsulasi data yang mendasari dan logika bisnis
Kontroler Tanggapi tindakan pengguna dan arahkan alur aplikasi
Melihat Memformat dan menyajikan data dari model ke pengguna.

Model

Model adalah komponen utama MVC yang secara langsung mengelola data, logika, dan batasan aplikasi. Ini terdiri dari komponen data, yang memelihara data aplikasi mentah dan logika aplikasi untuk antarmuka.

  • Ini adalah antarmuka pengguna independen dan menangkap perilaku domain masalah aplikasi.

  • Ini adalah simulasi perangkat lunak khusus domain atau implementasi dari struktur pusat aplikasi.

  • Ketika telah ada perubahan dalam statusnya, itu memberi pemberitahuan ke tampilan terkait untuk menghasilkan keluaran yang diperbarui dan pengontrol untuk mengubah set perintah yang tersedia.

Melihat

View dapat digunakan untuk merepresentasikan keluaran informasi dalam bentuk grafik seperti diagram atau grafik. Ini terdiri dari komponen presentasi yang memberikan representasi visual dari data

  • Views meminta informasi dari model mereka dan menghasilkan representasi keluaran kepada pengguna.

  • Beberapa tampilan dari informasi yang sama dimungkinkan, seperti diagram batang untuk manajemen dan tampilan tabel untuk akuntan.

Kontroler

Pengontrol menerima masukan dan mengubahnya menjadi perintah untuk model atau tampilan. Ini terdiri dari komponen pemrosesan input yang menangani input dari pengguna dengan memodifikasi model.

  • Ini bertindak sebagai antarmuka antara model dan tampilan terkait dan perangkat input.

  • Itu dapat mengirimkan perintah ke model untuk memperbarui status model dan ke tampilan terkait untuk mengubah presentasi tampilan model.

MVC - I

Ini adalah versi sederhana dari arsitektur MVC di mana sistem dibagi menjadi dua sub-sistem -

  • The Controller-View - Tampilan pengontrol bertindak sebagai antarmuka input / output dan pemrosesan selesai.

  • The Model - Model ini menyediakan semua layanan data dan domain.

MVC-I Architecture

Modul model memberi tahu modul tampilan pengontrol jika ada perubahan data sehingga tampilan data grafik apa pun akan diubah. Pengontrol juga mengambil tindakan yang tepat atas perubahan tersebut.

Hubungan antara controller-view dan model dapat dirancang dalam pola (seperti yang ditunjukkan pada gambar di atas) dari subscribe-notify dimana controller-view berlangganan model dan model memberi tahu controller-view jika ada perubahan.

MVC - II

MVC – II merupakan peningkatan dari arsitektur MVC-I yang memisahkan modul tampilan dan modul pengontrol. Modul model berperan aktif seperti pada MVC-I dengan menyediakan semua fungsionalitas inti dan data yang didukung oleh database.

Modul tampilan menyajikan data sementara modul pengontrol menerima permintaan masukan, memvalidasi data masukan, memulai model, tampilan, koneksinya, dan juga mengirimkan tugas.

MVC-II Architecture

Aplikasi MVC

Aplikasi MVC efektif untuk aplikasi interaktif di mana beberapa tampilan diperlukan untuk satu model data dan mudah untuk memasang tampilan antarmuka baru atau mengubah.

Aplikasi MVC cocok untuk aplikasi di mana terdapat divisi yang jelas antara modul sehingga profesional yang berbeda dapat ditugaskan untuk mengerjakan aspek yang berbeda dari aplikasi tersebut secara bersamaan.

Advantages

  • Ada banyak toolkit kerangka kerja vendor MVC yang tersedia.

  • Beberapa tampilan disinkronkan dengan model data yang sama.

  • Mudah untuk memasang plugin baru atau mengganti tampilan antarmuka.

  • Digunakan untuk pengembangan aplikasi di mana profesional keahlian grafis, profesional pemrograman, dan profesional pengembangan basis data bekerja dalam tim proyek yang dirancang.

Disadvantages

  • Tidak cocok untuk aplikasi berorientasi agen seperti aplikasi seluler dan robotika interaktif.

  • Beberapa pasang pengontrol dan tampilan berdasarkan model data yang sama membuat perubahan model data menjadi mahal.

  • Pembagian antara View dan Controller tidak jelas dalam beberapa kasus.

Presentation-Abstraction-Control (PAC)

Dalam PAC, sistem diatur menjadi hierarki dari banyak agen yang bekerja sama (triad). Ini dikembangkan dari MVC untuk mendukung persyaratan aplikasi beberapa agen selain persyaratan interaktif.

Setiap agen memiliki tiga komponen -

  • The presentation component - Memformat presentasi data visual dan audio.

  • The abstraction component - Mengambil dan memproses data.

  • The control component - Menangani tugas seperti aliran kendali dan komunikasi antara dua komponen lainnya.

Arsitektur PAC mirip dengan MVC, dalam artian modul presentasi seperti modul tampilan MVC. Modul abstraksi terlihat seperti modul model MVC dan modul kontrol seperti modul pengontrol MVC, tetapi mereka berbeda dalam aliran kontrol dan organisasinya.

Tidak ada hubungan langsung antara komponen abstraksi dan komponen presentasi di setiap agen. Komponen kontrol di setiap agen bertanggung jawab atas komunikasi dengan agen lain.

Gambar berikut menunjukkan diagram blok untuk agen tunggal dalam desain PAC.

PAC dengan Banyak Agen

Dalam PAC yang terdiri dari beberapa agen, agen tingkat atas menyediakan data inti dan logika bisnis. Agen tingkat bawah menentukan data dan presentasi spesifik yang terperinci. Agen level menengah atau menengah bertindak sebagai koordinator agen level rendah.

  • Setiap agen memiliki tugas khusus masing-masing.

  • Untuk beberapa agen tingkat menengah, presentasi interaktif tidak diperlukan, sehingga mereka tidak memiliki komponen presentasi.

  • Komponen kontrol diperlukan untuk semua agen yang melaluinya semua agen berkomunikasi satu sama lain.

Gambar berikut menunjukkan Beberapa Agen yang mengambil bagian dalam PAC.

Applications

  • Efektif untuk sistem interaktif di mana sistem tersebut dapat diuraikan menjadi banyak agen yang bekerja sama secara hierarkis.

  • Efektif bila kopling antar agent diharapkan lepas sehingga perubahan pada agent tidak mempengaruhi yang lain.

  • Efektif untuk sistem terdistribusi di mana semua agen terdistribusi jauh dan masing-masing memiliki fungsi sendiri dengan data dan antarmuka interaktif.

  • Cocok untuk aplikasi dengan komponen GUI yang kaya di mana masing-masing menyimpan datanya sendiri saat ini dan antarmuka interaktif dan perlu berkomunikasi dengan komponen lain.

Keuntungan

  • Dukungan untuk multi-tasking dan multi-viewing

  • Dukungan untuk penggunaan kembali dan perpanjangan agen

  • Mudah untuk memasukkan agen baru atau mengubah yang sudah ada

  • Dukungan untuk konkurensi di mana beberapa agen berjalan secara paralel di utas berbeda atau perangkat atau komputer berbeda

Kekurangan

  • Overhead karena jembatan kontrol antara presentasi dan abstraksi dan komunikasi kontrol di antara agen.

  • Sulit untuk menentukan jumlah agen yang tepat karena kopling longgar dan kemandirian yang tinggi antar agen.

  • Pemisahan lengkap presentasi dan abstraksi dengan kontrol di setiap agen menghasilkan kompleksitas pengembangan karena komunikasi antar agen hanya terjadi di antara kontrol agen