OOAD - Strategi Implementasi

Menerapkan desain berorientasi objek umumnya melibatkan penggunaan bahasa pemrograman berorientasi objek standar (OOPL) atau memetakan desain objek ke database. Dalam kebanyakan kasus, ini melibatkan keduanya.

Implementasi menggunakan Bahasa Pemrograman

Biasanya, tugas mengubah desain objek menjadi kode adalah proses yang mudah. Semua bahasa pemrograman berorientasi objek seperti C ++, Java, Smalltalk, C # dan Python, termasuk provisi untuk mewakili kelas. Dalam bab ini, kami memberikan contoh konsep menggunakan C ++.

Gambar berikut menunjukkan representasi lingkaran kelas menggunakan C ++.

Asosiasi Pelaksana

Kebanyakan bahasa pemrograman tidak menyediakan konstruksi untuk mengimplementasikan asosiasi secara langsung. Jadi, tugas pelaksana asosiasi perlu dipikirkan secara matang.

Asosiasi dapat berupa searah atau dua arah. Selain itu, setiap asosiasi dapat berupa satu-ke-satu, satu-ke-banyak, atau banyak-ke-banyak.

Asosiasi Searah

Untuk menerapkan asosiasi searah, kehati-hatian harus dilakukan agar searah dipertahankan. Implementasi untuk multiplisitas yang berbeda adalah sebagai berikut -

  • Optional Associations- Di sini, tautan mungkin ada atau mungkin tidak ada di antara objek yang berpartisipasi. Misalnya, dalam hubungan antara Pelanggan dan Rekening Koran pada gambar di bawah ini, pelanggan mungkin atau mungkin tidak memiliki rekening giro.

Untuk implementasi, objek Rekening Koran disertakan sebagai atribut di Pelanggan yang mungkin NULL. Implementasi menggunakan C ++ -

class Customer {
   private:
   // attributes
   Current_Account c; //an object of Current_Account as attribute
   
   public:  

   Customer() {
      c = NULL; 
   } // assign c as NULL

   Current_Account getCurrAc() {
      return c;
   }
   
   void setCurrAc( Current_Account myacc) {
      c = myacc;
   }

   void removeAcc() {  
      c = NULL;
   } 
};
  • One–to–one Associations- Di sini, satu instance kelas terkait dengan tepat satu instance kelas terkait. Misalnya, Departemen dan Manajer memiliki asosiasi satu-ke-satu seperti yang ditunjukkan pada gambar di bawah.

Ini diimplementasikan dengan memasukkan dalam Departemen, sebuah objek Manajer yang tidak boleh NULL. Implementasi menggunakan C ++ -

class Department {
   private:
   // attributes
   Manager mgr; //an object of Manager as attribute
   
   public:  
   Department (/*parameters*/, Manager m) { //m is not NULL   
      // assign parameters to variables
      mgr = m;
   } 

   Manager getMgr() {  
      return mgr;  
   }    
};
  • One–to–many Associations- Di sini, satu instance kelas terkait dengan lebih dari satu instance kelas terkait. Misalnya, perhatikan hubungan antara Karyawan dan Tanggungan pada gambar berikut.

Ini diimplementasikan dengan memasukkan daftar Tanggungan di kelas Karyawan. Implementasi menggunakan penampung daftar C ++ STL -

class Employee {
   private:
   char * deptName;
   list <Dependent> dep; //a list of Dependents as attribute

   public:  
   void addDependent ( Dependent d) { 
      dep.push_back(d); 
   } // adds an employee to the department

   void removeDeoendent( Dependent d) { 
      int index = find ( d, dep );
      // find() function returns the index of d in list dep
      dep.erase(index);
   }               
};

Asosiasi dua arah

Untuk menerapkan asosiasi dua arah, tautan di kedua arah perlu dipertahankan.

  • Optional or one–to–one Associations - Pertimbangkan hubungan antara Proyek dan Manajer Proyek yang memiliki asosiasi dua arah satu-ke-satu seperti yang ditunjukkan pada gambar di bawah ini.

Implementasi menggunakan C ++ -

Class Project {
   private:
   // attributes
   Project_Manager pmgr; 
   public:  
   void setManager ( Project_Manager pm);       
   Project_Manager changeManager();   
};

class Project_Manager {
   private:
   // attributes
   Project pj; 

   public:  
   void setProject(Project p);       
   Project removeProject();   
};
  • One–to–many Associations - Pertimbangkan hubungan antara Departemen dan Karyawan yang memiliki asosiasi satu ke banyak seperti yang ditunjukkan pada gambar di bawah.

Implementasi menggunakan container daftar C ++ STL

class Department {
   private:
   char * deptName;
   list <Employee> emp; //a list of Employees as attribute

   public:  
   void addEmployee ( Employee e) { 
      emp.push_back(e); 
   } // adds an employee to the department

   void removeEmployee( Employee e) { 
      int index = find ( e, emp );
      // find function returns the index of e in list emp
      emp.erase(index);
   }               
};

class Employee {
   private:
   //attributes
   Department d;

   public:
   void addDept();
   void removeDept();
};

Menerapkan Asosiasi sebagai Kelas

Jika sebuah asosiasi memiliki beberapa atribut yang terkait, itu harus diimplementasikan menggunakan kelas terpisah. Misalnya, pertimbangkan hubungan satu-ke-satu antara Karyawan dan Proyek seperti yang ditunjukkan pada gambar di bawah ini.

Implementasi WorksOn menggunakan C ++

class WorksOn {
   private:
   Employee e; 
   Project p;
   Hours h;
   char * date;

   public:
   // class methods
};

Menerapkan Batasan

Batasan di kelas membatasi rentang dan jenis nilai yang dapat diambil atribut. Untuk mengimplementasikan batasan, nilai default yang valid diberikan ke atribut ketika sebuah objek dibuat instance dari kelas. Setiap kali nilai diubah saat runtime, itu akan diperiksa apakah nilainya valid atau tidak. Nilai yang tidak valid dapat ditangani oleh rutinitas penanganan pengecualian atau metode lain.

Example

Pertimbangkan kelas Karyawan di mana usia adalah atribut yang mungkin memiliki nilai dalam kisaran 18 hingga 60. Kode C ++ berikut menggabungkannya -

class Employee {
   private: char * name;
   int age;
   // other attributes

   public:
   Employee() {                   // default constructor 
      strcpy(name, "");
      age = 18;                // default value
   }
 
   class AgeError {};          // Exception class
   void changeAge( int a) {   // method that changes age 
      if ( a < 18 || a > 60 )  // check for invalid condition
      throw AgeError();        // throw exception
      age = a;			
   }
};

Menerapkan State Charts

Ada dua strategi implementasi alternatif untuk mengimplementasikan status dalam diagram diagram status.

Pencacahan dalam Kelas

Dalam pendekatan ini, status diwakili oleh nilai yang berbeda dari anggota data (atau kumpulan anggota data). Nilai-nilai secara eksplisit ditentukan oleh pencacahan di dalam kelas. Transisi diwakili oleh fungsi anggota yang mengubah nilai anggota data yang bersangkutan.

Pengaturan Kelas dalam Hirarki Generalisasi

Dalam pendekatan ini, status diatur dalam hierarki generalisasi dengan cara yang dapat dirujuk oleh variabel penunjuk umum. Gambar berikut menunjukkan transformasi dari diagram bagan status ke hierarki generalisasi.

Pemetaan Objek ke Sistem Database

Persistensi Objek

Aspek penting dalam mengembangkan sistem berorientasi objek adalah persistensi data. Melalui persistensi, objek memiliki umur yang lebih lama daripada program yang membuatnya. Data persisten disimpan di media penyimpanan sekunder dari mana ia dapat dimuat ulang bila diperlukan.

Tinjauan RDBMS

Database adalah kumpulan data terkait yang dipesan.

Sistem manajemen basis data (DBMS) adalah kumpulan perangkat lunak yang memfasilitasi proses untuk menentukan, membuat, menyimpan, memanipulasi, mengambil, berbagi, dan menghapus data dalam basis data.

Dalam sistem manajemen basis data relasional (RDBMS), data disimpan sebagai relasi atau tabel, di mana setiap kolom atau bidang mewakili atribut dan setiap baris atau tupel mewakili catatan suatu instance.

Setiap baris secara unik diidentifikasi oleh sekumpulan atribut minimal yang dipilih primary key.

SEBUAH foreign key adalah atribut yang merupakan kunci utama dari tabel terkait.

Mewakili Kelas sebagai Tabel di RDBMS

Untuk memetakan kelas ke tabel database, setiap atribut direpresentasikan sebagai bidang dalam tabel. Entah atribut yang ada ditetapkan sebagai kunci utama atau bidang ID terpisah ditambahkan sebagai kunci utama. Kelas dapat dipartisi secara horizontal atau vertikal sesuai kebutuhan.

Misalnya, kelas Circle dapat diubah menjadi tabel seperti yang ditunjukkan pada gambar di bawah ini.

Schema for Circle Table: CIRCLE(CID, X_COORD, Y_COORD, RADIUS, COLOR)
Creating a Table Circle using SQL command:
CREATE TABLE CIRCLE (   
   CID	VARCHAR2(4) PRIMARY KEY,
   X_COORD INTEGER NOT NULL,
   Y_COORD INTEGER NOT NULL,
   Z_COORD INTEGER NOT NULL,
   COLOR 
);

Memetakan Asosiasi ke Tabel Database

Asosiasi Satu-ke-Satu

Untuk mengimplementasikan asosiasi 1: 1, kunci utama dari salah satu tabel ditetapkan sebagai kunci asing dari tabel lainnya. Misalnya, pertimbangkan hubungan antara Departemen dan Manajer -

Perintah SQL untuk membuat tabel

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
   EMPID INTEGER REFERENCES MANAGER 
);

CREATE TABLE MANAGER ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
);

Asosiasi Satu ke Banyak

Untuk mengimplementasikan asosiasi 1: N, kunci utama tabel di sisi 1 dari asosiasi ditetapkan sebagai kunci asing tabel di sisi-N dari asosiasi. Misalnya, pertimbangkan hubungan antara Departemen dan Karyawan -

Perintah SQL untuk membuat tabel

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
);

CREATE TABLE EMPLOYEE ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
   D_ID INTEGER REFERENCES DEPARTMENT
);

Asosiasi Banyak-ke-Banyak

Untuk mengimplementasikan asosiasi M: N, relasi baru dibuat yang mewakili asosiasi tersebut. Misalnya, pertimbangkan hubungan berikut antara Karyawan dan Proyek -

Schema for Works_On Table - WORKS_ON (EMPID, PID, JAM, START_DATE)

SQL command to create Works_On association - BUAT TABEL WORKS_ON

( 
   EMPID INTEGER,
   PID INTEGER, 
   HOURS INTEGER,
   START_DATE DATE,
   PRIMARY KEY (EMPID, PID),
   FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
   FOREIGN KEY (PID) REFERENCES PROJECT 
);

Memetakan Warisan ke Tabel

Untuk memetakan warisan, kunci utama dari tabel dasar ditetapkan sebagai kunci utama serta kunci asing dalam tabel turunan.

Example