OOP မှာ အမျိုးအစား လေးမျိုးရှိတယ်။
Abstraction
Abstraction ကတော့ အလုပ်ခွဲခြားလုပ်ကိုင်ခြင်းလို့ခေါ်ပါတယ်။ သူ့အလုပ်သူ လုပ်စေတာပေါ့။ ဉပမာ - စားသောက်ဆိုင်မှာဆိုရင် ဝိတ်တာက ဝိတ်တာအလုပ်လုပ်မယ်၊ စားဖိုမှူးက စားဖိုမှုးအလုပ်ပေါ့၊ ငွေကိုင်က ငွေကိုင်အလုပ် ခွဲခြားလုပ်ကိုင်ခြင်းကိုခေါ်တာပါ။ တစ်ယောက်တည်း တစ်ခုတည်းက အကုန်လုပ်နေရင် အဆင်မပြေဘူးလေ။ တိုင်ပတ်သွားနိုင်တယ်။ ဒ့ါကြောင့် Code တွေရေးတဲ့အခါမှာလည်း Abstraction လို့ခေါ်တဲ့ Function တွေ၊ Class တွေ၊ Object တွေကို ခွဲခြားရေးသင့်ပါတယ်။
Encapsulation
Encapsulation ကတော့ အသေးစား ဆုံးဖြတ်ချက်တွေ ချတဲ့အပိုင်းလို့ ဆိုနိုင်ပါတယ်။ ဉပမာ - စားပွဲထိုးက စားဖိုမှုးကို ဟင်းဘယ်လိုချက်ရမယ် သွားပြောနေလို့အဆင်ပြေဘူးလေ။ ဒီတော့ စားဖိုမှုးက ဟင်းဘယ်လိုချက်မယ်၊ ဘယ်ပြင်ဆင်မလဲဆိုတာ သူကိုယ်တိုင် ဆုံးဖြတ်ချက်ချရမယ်။ ဒါ့ကြောင့်လဲ စားသောက်ဆိုင်တွေမှာ မီးဖိုချောင်ကသက်သက်ထားတာပေါ့။ Coding မှာဆိုရင်တော့ ဉပမာ မေးခွန်နဲ့အဖြေ ပေးတဲ့ App တွေ ဆိုပါစို့။ မေးခွန်းတွေအဖြေတွေ ဆုံးဖြတ်ပေးတာကို သက်ဆိုင်ရာ Function ကပဲ ဆုံးဖြတ်ပိုင်ခွင့်ပေးတာမျိုးပါ။ မဆိုင်တဲ့ Function ကနေဆုံးဖြတ်ချက် ပေးတာမျိုးက မဖြစ်သင့်ပါဘူး။
ဒီတော့ ကျွန်တော်တို့ properties တွေကို private အနေနဲ့ သုံးစွဲရပါတယ်။ ဒီလိုသုံးစွဲဖို့ရင် properties name ရဲ့ရှေ့ underscore ထည့်ပေးရပါတယ်။
List<Question> _questionBank = [
];
ဒီတော့ ကျွန်တော်တို့အနေနဲ့ private properties တွေကို အသုံးပြုဖို့ဆိုရင် Function အသစ်တစ်ခု create လုပ်ပေးရပါတယ်။ ဉပမာ -
String getQuestionNumber(int questionNumber){
return _questionBank[quesitonNumber].questionText;
}
bool getQuestionAnswer(int questionNumber){
return _questionBank[questionNumber].questionAnswer;
}
ဒီသင်ခန်းစာမှာဆိုရင် ကျွန်တော်တို့ app က question ကုန်သွားလည်း ထပ်ပြီး questionNumber
ကို ပေါင်းနေတဲ့အတွက် Error result ရရှိပါတယ်။ ဒါကို fix ဖို့အတွက် main.dart file ထဲက int questionNumber = 0;
ကို quiz_brain.dart ဖိုင်ထဲက QuizBrain Class ထဲကိုထည့်လိုက်ပါမယ်။ ပြီးရင်တော့ သူ့ကိုလည်း private properties ပြောင်းလိုက်ပါတယ်။ int _quesitonNumber = 0;
ဒါ့အပြင် ကျွန်တော်တို့ စောစောက ရေးထား code ကိုလည်း အောက်ပါအတိုင်းပြင်လိုက်ပါမယ်။
String getQuestionNumber(){
return _questionBank[_quesitonNumber].questionText;
}
bool getQuestionAnswer(){
return _questionBank[_questionNumber].questionAnswer;
}
ပြီးရင်တော့ သူ့အတွက်ကျွန်တော်တို့ method တစ်ခု create လုပ်ပါမယ်။
void nextQuesiton (){
if(_questionNumber< _questionBank.length - 1){
_questionNumber++;
}
}
Inheritance
Inheritance ကတော့ မျိုးရိုးဗီဇ ဇယားပုံစံ နည်းသွားဆင်ပါတယ်။ ကျွန်တော်တို့အနေနဲ့ တူညီတဲ့ properties တွေကို ထပ်ခါထပ်ခါမရေးပဲ dart မှာဆိုရင် extends လုပ်ပြီး အသုံးပြုလို့ရနိုင်တာပဲဖြစ်ပါတယ်။ ဉပမာ -
void main {
//အောက်မှာရေးထားတဲ့ class ကို object အဖြစ်သုံးမယ်ဆိုရင်
Car myNormalCar = Car();
print(myNormalCar.numberofSeats); //ဒါဆိုရင် အောက်က class ရဲ့ properties ဖြစ်တဲ့ 5 ဆိုတဲ့ ရလဒ်ရရှိမျာပဲဖြစ်ပါတယ်။
//Inheritance အဖြစ်အသုံးပြုခြင်း
ElectricCar myTesla = ElectricCar();
myElectricCar.drive(); // ဒါဆိုရင် Car Class ရဲ့ drive method ကိုတိုက်ရိုက်သုံးစွဲလို့ရသွားမှာပဲဖြစ်ပါတယ်။
}
//car ဆိုတဲ့ class အသစ်တစ်ခု ရေးလိုက်မယ်
class Car(){
int numberOfSeats = 5; //ဒါကတော့ properties ပဲဖြစ်ပါတယ်။
void drive(){
print('wheels start turn.'); // ဒါကတော့ method ပဲဖြစ်ပါတယ်။
}
}
//နောက် class တစ်ခုအနေနဲ့ Inheritance အဖြစ်သုံးမယ်ဆိုရင်
class ElectricCar extends Car(){
//Car(); class ရဲ့ properties တွေနဲ့ method တွေကို တခါတည်းရရှိသွားမှာ ဖြစ်ပါတယ်။
//ဒ့ါအဖြစ် properties အသစ်တွေနဲ့ method အသစ်တွေကိုပါ ထည့်သွင်းအသုံးပြုလို့ရမျာဖြစ်ပါတယ်။
int batteryLevel = 100;
void recharge(){
batteryLevel = 100;
}
Polymorphism
Polymorphism ကတော့ custom behavior တွေ create လုပ်တဲ့နေရာမှာအသုံးပြုပါတယ်။ Inheritance လုပ်ထားတဲ့ class ကိုမှာ ကိုယ်ပိုင် style (သို့) properties တွေကို စိတ်ကြိုက် ပြင်ဆင်သုံးစွဲနိုင်ခြင်းပဲဖြစ်ပါတယ်။ ဉပမာ
void main {
//အောက်မှာရေးထားတဲ့ class ကို object အဖြစ်သုံးမယ်ဆိုရင်
Car myNormalCar = Car();
print(myNormalCar.numberofSeats); //ဒါဆိုရင် အောက်က class ရဲ့ properties ဖြစ်တဲ့ 5 ဆိုတဲ့ ရလဒ်ရရှိမျာပဲဖြစ်ပါတယ်။
//Inheritance အဖြစ်အသုံးပြုခြင်း
ElectricCar myTesla = ElectricCar();
myElectricCar.drive(); // ဒါဆိုရင် Car Class ရဲ့ drive method ကိုတိုက်ရိုက်သုံးစွဲလို့ရသွားမှာပဲဖြစ်ပါတယ်။
//Polymorphism အဖြစ်အသုံးပြုခြင်း
LevitatingCar myMagLev= LevitatingCar();
myMagLev.drive(); // ဒါဆိုရင် Car Class ရဲ့ drive method ကိုမသုံးပဲ Polymorphism (တနည်းအားဖြင့် overwrite)လုပ်ထားတဲ့ method ကိုသုံးစွဲသွားတာ တွေ့ရမှာပဲဖြစ်ပါတယ်။
//Polymorphism ကို မူရင်း Method ဖြင့်တွဲဖက်အသုံးပြုခြင်း
//ထုံးစံအတိုင်း object တည်ဆောက်မယ်
SelfDrivingCar myWaymo = SelfDrivingCar('1 Hacker way');//ဒီနေရာမှာ ကျွန်တော်တို့ value တစ်ခုခု input လုပ်ပေးရပါတယ်။
myWaymo.drive(); //ဒီလိုခေါ်လိုက်မယ်ဆိုရင်တော့ မူရင်း method ရော customize လုပ်ထားတဲ့ method ရောပါ တွဲဖက်ဖော်ပြပေးမှာပဲဖြစ်ပါတယ်။
}
//car ဆိုတဲ့ class အသစ်တစ်ခု ရေးလိုက်မယ်
class Car(){
int numberOfSeats = 5; //ဒါကတော့ properties ပဲဖြစ်ပါတယ်။
void drive(){
print('wheels start turn.'); // ဒါကတော့ method ပဲဖြစ်ပါတယ်။
}
}
//နောက် class တစ်ခုအနေနဲ့ Inheritance အဖြစ်သုံးမယ်ဆိုရင်
class ElectricCar extends Car(){
//Car(); class ရဲ့ properties တွေနဲ့ method တွေကို တခါတည်းရရှိသွားမှာ ဖြစ်ပါတယ်။
//ဒ့ါအဖြစ် properties အသစ်တွေနဲ့ method အသစ်တွေကိုပါ ထည့်သွင်းအသုံးပြုလို့ရမျာဖြစ်ပါတယ်။
int batteryLevel = 100;
void recharge(){
batteryLevel = 100;
}
class LevitatingCar extends Car { //Class တွေရဲ့ အစ စာကလုံးတွေဟာ အကြီးနဲ့စပါတယ်။
//Polymorphism လုပ်ဖို့အတွက်ဆိုရင် အရင်ဆုံး overwrite လုပ်ရပါတယ်။ ဒါ့ကြောင့်
@override
//အဲ့ဒီနောက်မှာတော့ ကိုယ်ပိုင် style နဲ့ customize လုပ်လို့ရပြီပဲဖြစ်ပါတယ်။
void drive(){
print('glide forwards');
}
}
//နောက်တစ်နည်းအသုံးပြုလို့ရတာကတော့ Parent class ရဲ့ method နဲ့ customize လုပ်ထားတဲ့ method ကို တွဲသုံးခြင်းဖြစ်ပါတယ်။
class SelfDrivingCar extends Car {
String destination;
//constructor တည်ဆောက်မယ်ဆိုရင်
SelfDrivingCar (String userSetDestination){
destination = userSetDestination;
}
// အဲ့ဒီနောက်မှာ overwrite လုပ်ပါမယ်။
@override
super.drive(); //super ကိုအသုံးပြုခြင်းအားဖြင့် overwrite လုပ်သော်လည်း မူရင်း method ပျောက်မသွားပါဘူး။
print('sterring towards $destination'); //နောက်ထပ် method တစ်ခုကို create လုပ်လိုက်တာပဲဖြစ်ပါတယ်။
}