ကြ်န္ေတာ္ ေနာက္ဆံုး ေရးခဲ့တဲ့ - Post ႏွစ္ခု မွာ OOP၊ Frameworks တို႕နဲ႕ပက္သက္ျပီး အျငင္းပြားဖြယ္ရာတစ္ခ်ိဳ႕ ေျပာထားခဲ့မိတာ ရွိပါတယ္... အခု Framework နဲ႕ ပက္သက္ျပီး ဆက္ေျပာခ်င္ပါတယ္...

Abstractions

အခုခ်ိန္မွာ MS-DOS ကို ရံုးသံုး Operating System တစ္ခုအေနနဲ႕ အသံုးျပဳဖို႕ဆိုတာ စိတ္ကူးၾကည့္လို႕ေတာင္ မရေတာ့သလို လိုလဲ မလိုအပ္ေတာ့ပါဘူး... အဲ့ဒီ ၁၉၈၁ ခုႏွစ္ေလာက္က စခဲ့တဲ့ MS-DOS အေပၚမွာ အေျခခံျပီး ကေန႕ေခတ္ Windows ေတြရဲ႕ အစျဖစ္တဲ့ Windows 3.x, Windows 95, စသျဖင့္ ေပၚေပါက္လာပါတယ္... ခ်က္ခ်င္းၾကီး Windows 95 ဆိုျပီး ေပၚလာတာ မဟုတ္ပါဘူး... MS-DOS ဆိုတဲ့ Command Line Operating System အေပၚ အေျခခံျပီးမွသာ ျဖစ္လာရတာပါ...

Windows တစ္ခုျဖစ္လာဖို႕ နည္းပညာ Layer ေတြ အဆင့္ဆင့္ထပ္ျပီး တည္ေဆာက္ထားရတာပါ... အဆင့္ဆင့္ ဘယ္ေလာက္ ထပ္ထားမွန္း ကြ်န္ေတာ္တို႕ အတိအက် မသိႏုိင္ပါဘူး...

Linux OS ေတြမွာလဲ အတူတူပါပဲ... Linux Kernel ေပၚမွာ User Interface အတြက္ X Window System က Run ေနရျပီး၊ X Window System ေပၚမွာမွ Gnome Desktop Environment လို DE ေတြ ထပ္ ထားရပါတယ္... အဲ့လို အဆင့္ဆင့္ ထပ္ထားျပီး Debian Packaging System (apt) နဲ႕ ေပါင္းစပ္လိုက္ေတာ့မွာ ကြ်န္ေတာ္တို႕ သံုးေနတဲ့ Ubuntu Linux ဆုိတာျဖစ္လာတာပါ... သူလဲ Layer ေတြ အဆင့္ဆင့္ ထပ္ထားတာပါပဲ...

Programming Language ေတြမွာလဲ အတူတူပါပဲ... Assembly Language ကို အေျခခံျပီး C/C++ ျဖစ္လာသလို C/C++ ကုိ အေျခခံျပီး Java / C# စသျဖင့္ ျဖစ္လာတာပါ... Java ဆိုတဲ့ Programming Language ရုတ္တရက္ ေပၚလာတာမ်ိဳး မဟုတ္ပါဘူး... အဲ့ဒီလို အဆင့္ဆင့္ အေျခခံခဲ့လို႕လဲ ျပည့္စံုတဲ့ Java Programming Language ဆိုျပီး ျဖစ္လာတာပါ...

ကြန္ျပဴတာ နည္းပညာ ဘယ္ကတည္းက အစျပဳခဲ့မွန္း အတိအက် မသိေပမယ့္ ၁၉၈၀ ေက်ာ္မွာ Personal Computer ဆိုျပီး စတင္လိုက္ကတည္း ကြန္ျပဴတာနည္းပညာ အရွိန္အဟုန္နဲ႕ တိုးတက္လာလိုက္တာ အခုဆိုရင္ ႏွစ္ေပါင္း (၃၀)ျပည့္ဖို႕ နီးလာပါျပီ... အဲ့ဒီ ႏွစ္ေတြအတြင္းမွာ နည္းပညာေတြ တစ္ခုအေပၚတစ္ခုဆင့္ျပီး ဘယ္ေလာက္ေတာင္ ထပ္ထပ္ ထားသလဲဆိုတာ မွန္းၾကည့္လို႕ မရႏုိင္ေတာ့ပါဘူး...

လုိရင္းေျပာရရင္ေတာ့ ကေန႕ ကြ်န္ေတာ္တို႕ သံုးေနတဲ့ နည္းပညာ အားလံုးဟာ Layer အဆင့္ဆင့္ ထပ္ျပီး တည္ေဆာက္လာခဲ့တာျဖစ္သလို အဲ့ဒီလို အဆင့္ဆင့္ တည္ေဆာက္ခဲ့လို႕လဲ ျပည့္စံု ေကာင္းမြန္ေနတာ ျဖစ္ပါတယ္...

အဲ့ဒီ Layer အဆင့္ဆင့္ကို နားမလည္ပဲ လက္ရွိ ေနာက္ဆံုးအဆင့္ကိုပဲ သံုးတက္တဲ့သူကို User လို႕ေခၚျပီး Layer အဆင့္ဆင့္ကို နားလည္တဲ့သူကို Computer Technician (Scientist, Professional) လို႕ ေခၚတာလို႕ ျမင္မိပါတယ္...

Frameworks

Software Frameworks ဆိုတာကို အမ်ိဳးမ်ိဳး အဓိပၸါယ္ဖြင့္ဆိုလို႕ ရေပမယ့္၊ အရိုးရွင္းဆံုး ေျပာရရင္...
Frameworks ဆိုတာဟာ၊ Productive ျဖစ္ဖို႕အတြက္၊ အစစအရာရာ လိုက္ေရးေနစရာမလိုေအာင္၊ အသင့္ေရးထားေပးတဲ့၊ အသင့္သံုး Functions ေတြ စုစည္းထားတဲ့၊ Library တစ္ခုပဲျဖစ္ပါတယ္...
Framework ဆိုတာဟာ Programming Language အေပၚမွာ ထပ္အုပ္ထားတဲ့ Layer ေနာက္တစ္ထပ္ပဲ ျဖစ္ပါတယ္...

အဲ့ဒါကို နားမလည္ပဲ Program ေရးေနသူေတြကို IDE User လို႕ ေခၚခ်င္ျပီး Framework ဆိုတာဟာ Programming Language အေပၚက Layer တစ္ထပ္မွ်သာျဖစ္တယ္လို႕ နားလည္ထားသူကို Programmer လို႕ ေခၚခ်င္ပါတယ္...

Why Frameworks Suck?

Layer တစ္ထပ္ ထပ္လိုက္တိုင္း ဟာကြက္ေတြ ယိုေပါက္ေတြတိုးလာပါတယ္... အဲ့ဒီအေၾကာင္း အေသးစိတ္ ဒီေနရာမွာ မေျပာႏုိင္ပါဘူး... Joel Spolsky ရဲ႕ Leaky Abstractions ဆိုတဲ့ Article ကို ဖတ္ၾကည့္ေစခ်င္ပါတယ္...

ဥပမာ တစ္ခုအေနနဲ႕ ASP.NET Framework မွာ ရွိေနတဲ့ Leak တစ္ခုကို ျပခ်င္ပါတယ္...

HTTP နဲ႕ Web Technology အရ Web ဆိုတာဟာ Event Driven မဟုတ္ပါဘူး... ASP.NET က Web Development ကို Windows Application Development ကဲ့သုိ႕ Event Driven သဖြယ္ Develop လုပ္လို႕ရေအာင္ လုပ္ေဆာင္ထားေပးပါတယ္...

ဒီလို Event Driven ျဖစ္လာဖို႕ ေနာက္ကြယ္ကေန Dirty Work ေတြ အမ်ားၾကီးလုပ္ရပါတယ္... ဥပမာ Post Back အတြက္ View States ေတြကို HTML Hidden Box ထဲမွာ Encrypt လုပ္မွတ္ထားရပါတယ္...

အဲ့ဒီ Behind the Scene လုပ္သြားတဲ့ Dirty Work ေတြကို Developer ေတြအေနနဲ႕ သိစရာမလိုပါဘူး... ASP Button Control တစ္ခုထည့္.. Double Click ေလးလုပ္ျပီး Button1_Click Event ထဲမွာ Code ေလးေတြ ေရးယံုပါပဲ...

သိစရာမလိုေတာ့ Developer ေတြ မသိၾကေတာ့ပါဘူး... (MITP မွာေတာင္ ေနာက္ကြယ္မွာ ဘာလုပ္သြားလဲ သိစရာမလိုဘူး ေျပာတဲ့သူေတြ ရွိပါတယ္ :) အဲ့ဒီလို မသိၾကေတာ့ ျပႆနာေတြ တက္ေတာ့တာပါပဲ...

ASP page တစ္ခုထဲကို asp Text Box control ႏွစ္ခု နဲ႕ Button control တစ္ခု ထည့္ပါ... Button ကို ႏွိပ္လုိက္ရင္ ပထမ Text Box ထဲကစာကို ဒုတိယ Text Box ထဲကို ကူးထည့္ေအာင္ ေရးပါ... ဘယ္ ASP.NET Developer မဆို ေရးတက္ပါတယ္... ျပီေတာ့မွ Page_Load မွာ ပထမ Text Box ကို Clear လုပ္ပါ...

ပထမ Text Box ထဲကို စာရိုက္ထည့္ျပီး Button ကို ႏွိပ္ၾကည့္ပါ...

Button ကို ႏွိပ္လုိက္ရင္ ပထမ Text Box ထဲက စာကို ဒုတိယ Text Box ထဲကို ကူးထည့္ရမွာ ျဖစ္ေပမယ့္ ဘာမွ ေပၚလာမွာမဟုတ္ပါဘူး.. ဘာျဖစ္လို႕လဲဆုိေတာ့ Event Driven စစ္စစ္မဟုတ္ပဲ Event Driven လို႕ ထင္ရေအာင္ လုပ္ထားတာမို႕လို႕ပါ... HTTP protocol က နဂိုကတည္းက တစ္ၾကိမ္ Request လုပ္မွ တစ္ၾကိမ္ Respond လုပ္တဲ့ Stateless System ျဖစ္လို႕ Button ကို ႏွိပ္လုိက္တာနဲ႕ Page ကို reload ျပန္လုပ္ေနပါတယ္... ဒါေၾကာင့္ Button ႏွိပ္တာနဲ႕ မဆီမဆုိင္ Page Load က အလုပ္ကိုပါ သြားလုပ္ေနပါတယ္... ဒီလို ကိစၥေတြအမ်ားၾကီးပါ...

Web Technology ကို နားလည္ထားတဲ့ Programmer ေတြနဲ႕၊ .NET Framework က ေနာက္ကြယ္မွာ ဘာေတြလုပ္သြားလဲ ဆိုတာကို နားလည္ထားတဲ့သူေတြအတြက္ ျပႆနာ မဟုတ္ေပမယ့္ IDE User ေတြအတြက္ေတာ့ တစ္ကယ့္ကို ျပႆနာ အၾကီးၾကီး ျဖစ္ႏုိင္ပါတယ္...

ကြန္ျပဴတာပညာေရး ႏွင့္ Frameworks/IDE

ကြ်န္ေတာ္တို႕ဆီမွာ Computer Science ကို စနစ္တစ္က် သင္ခဲ့ရတဲ့သူ သိပ္မရွိသလို သင္တန္းေတြကလည္း IDE User ေတြကိုသာ ေမြးထုပ္ေပးေနတဲ့အတြက္ သံုးမရတဲ့ IDE User ေတြ ပံုေနပါတယ္... သူတို႕ကို ASP.NET နဲ႕ Web site တစ္ခုေရးခိုင္းရင္ ေရးႏုိင္ပါတယ္... ဘာျဖစ္လို႕လဲဆိုေတာ့ Programming စစ္စစ္ကုိ မတက္ေပမယ့္ Visual Studio ဘယ္လိုသံုးရမလဲဆုိတာေတာ့ သူတို႕ ေကာင္းေကာင္း သိပါတယ္... သူမ်ားေတြဆီမွာေတာ့ မသိပါဘူး... ကြ်န္ေတာ္တို႕ ဆီမွာေတာ့ Frameworks ေတြနဲ႕ IDE ေတြက၊ သင္တန္းေတြနဲ႕ပူးေပါင္းျပီး Programmer ျဖစ္လာရမယ့္သူေတြကို IDE User ျဖစ္ကုန္ေအာင္ ဖ်က္ဆီးေနၾကပါတယ္...

ကြ်န္ေတာ္က Frameworks ေတြ မေကာင္းဘူး မေကာင္းဘူး ေျပာေနေတာ့ တစ္ျခား အေၾကာင္းေၾကာင့္ ထင္ၾကပါတယ္... အမွန္ေတာ့ ဒီကိစၥက အဓိကပါ...

ဒါေၾကာင့္ ျမန္မာျပည္က Programming သင္တန္းတက္ေနတဲ့ ေက်ာင္းသားေတြနဲ႕ သင္တန္းဆင္းစ IDE User ေတြကို၊ Programmer စစ္စစ္ ျဖစ္ခ်င္ရင္ သံုးေနတဲ့ IDE ေတြ Framework ေတြကို အခုခ်က္ျခင္းပစ္ခ်ျပီး Programming Language စစ္စစ္ကို ေလ့လာၾကဖို႕ ဒီေနရာကေန တိုက္တြန္းလိုပါတယ္...

တစ္ျခား Framework ေတြကို မၾကိဳက္ရတဲ့ အခ်က္တစ္ခ်ိဳ႕ကေတာ့...

  1. တစ္ခါတစ္ရံ ရိုးရွင္းတဲ့ ျပႆနာအတြက္ Frameworks ေတြရဲ႕ Convention ေတြ Structure ေတြကို လိုက္နာရတဲ့အတြက္ မလိုအပ္ပဲ ရွဳပ္ေထြးမွဳေတြ ပိုေစတယ္
  2. တစ္ခါတစ္ရံ ကိုယ္တုိင္ေရးလိုက္တာက Framework က Provide လုပ္တဲ့ Library ကို နားလည္ေအာင္ ေလ့လာရတာထက္ ပိုျမန္တယ္
  3. တစ္ခါတစ္ရံ Framework က Boundary လို ျဖစ္ေနျပီး သူေပးသေလာက္ပဲ လုပ္ရတဲ့အတြက္ လြပ္လပ္မွဳမရွိသလို ျဖစ္တက္တယ္... ASP.NET Web Site အေတာ္မ်ားမ်ားကို ၾကည့္လိုက္ရင္ တစ္ခုနဲ႕တစ္ခု ကြဲျပားမွဳသိပ္မရွိပဲ Framework က ေပးထားတာေတြကိုသာ သံုးထားတာ မ်ားတာကို ေတြ႕ရပါတယ္
  4. တစ္ခါတစ္ရံ မလိုအပ္ပဲ Library ေတြ တစ္ပံုၾကီး Loading လုပ္ရတဲ့အတြက္ ေႏွးပါတယ္... ASP.NET ဆိုရင္ compile အရင္လုပ္လို႕ PHP, Python တို႕လို Interpreted Language ေတြထက္ ျမန္တယ္ျမန္တယ္ေျပာေနျပီး Run Time မွာ Library ေတြ Component ေတြ တစ္ပံုၾကီး Load လုပ္ရတာေတြ၊ တစ္ခ်ိဳ႕ Behind the Scene Process တစ္ခ်ိဳ႕ေတြေၾကာင့္ လက္ေတြ႕မွာ အေတာ္ေလး ေႏွးတာကို ေတြ႕ရပါတယ္...

အမွန္ေတာ့ အဲ့ဒါေတြက Minor Reason ေတြပါ... Major Reason ကေတာ့ တစ္ကယ္ အေရးၾကီးတဲ့ Programming Language နဲ႕ Technology ေတြကို သိစရာ မလိုေတာ့သေယာင္ေယာင္ ျဖစ္ေအာင္ လုပ္ထားလို႕ပါ... Navigation နဲ႕ Paging ပါတဲ့ Image Rotate Circle Effect ကို Flash နဲ႕မွ လုပ္လို႕ရတယ္ထင္တဲ့၊ အေတြ႕အၾကံဳရွိပါတယ္ဆိုတဲ့ ASP.NET Developer ေတြ တစ္ပံုၾကီးပါ...

ကြ်န္ေတာ့္အျမင္မွာ နည္းပညာနဲ႕ အသုံးျပဳမယ့္ Programming Language ကို ေကာင္းေကာင္းနားလည္ျပီးသား Programmer ေတြအတြက္၊ Frameworks ေတြဟာ အေကာင္းဆံုး မိတ္ေဆြ ျဖစ္ပါလိမ့္မယ္... Productive ျဖစ္ေအာင္ ကူညီျပီး .NET Framework ကေျပာေနတဲ့ Rapid Development ကို ရမွာပါ... ဒါေပမယ့္ IDE User ေတြအတြက္ေတာ့ Frameworks ေတြဟာ သူတို႕ကို IDE User ျဖစ္ေအာင္ လုပ္ေနတဲ့ အၾကီးမားဆံုး ရန္သူေတြပါပဲ...

--
[ Ei Maung ]

Views: 181

Tags: asp.net, framework, rant

Comment

You need to be a member of MyanmarITPro - A Social Network for Myanmar IT Professionals to add comments!

Join MyanmarITPro - A Social Network for Myanmar IT Professionals

Comment by Sky@Napster on October 22, 2009 at 11:33pm
ေကာင္းကြာ....ကိုယ့္ကိုကိုယ္ IDE User ျဖစ္ေနမွန္း ခုမွသိေတာ့တယ္...
ေငြထုပ္မွတ္လို႕ ခါးပိုက္ပိုက္ထားတာ လက္စသတ္ေတာ့ ေျမြေပြးခါးပိုက္ပိုက္မိရက္သားျဖစ္ေနတာကို.

ကိုအိေမာင္၊ ကိုျမင့္ေက်ာ္သူတို႕ အားရင္ေပါ့ဗ်ာ...ကိုယ္ပိုင္ framework ေလးဘယ္လိုလုပ္ရမလည္းဆိုတာ postေလးတင္ရင္ သိပ္ေကာင္းဗ်ာ... ေလ့လာခ်င္တဲ့လူေတြအတြက္ ေရငတ္တုန္း ေရတြင္းထည္းက်သလိုျဖစ္မွာ အမွန္ပဲ..
Comment by Ei Maung on October 18, 2009 at 11:21am
>> I will definitely use SilverLight if I don't want my application/games to be used by a lot of users

Oh! You shouldn't said like that even if it's true... Just joking.... :P
Comment by Myint Kyaw Thu on October 18, 2009 at 9:42am
>> So you can transform your app to Silverlight which will run inside web browser.

No, thank you :) I will definitely use SilverLight if I don't want my application/games to be used by a lot of users :P SilverLight is going to die soon and Flash will prevail!!!
Comment by Mark on October 17, 2009 at 9:59pm
>> But I don't have logic
no problem, not logic challanges, just language challenges, you can just convert to ruby codes

>> What are you waiting for bro? Please start a topic... :)
ok bro, :D

Mark
Comment by Ei Maung on October 17, 2009 at 9:35pm
@Mark
>> the roman converter "CCXCIV" to 294 with one line of python? :D
Good idea. But I don't have logic. You start first please. I will follow with Ruby version...

>> we can start giving challenge examples each others and compete it? how do u think?
What are you waiting for bro? Please start a topic... :)
Comment by Mark on October 17, 2009 at 5:54pm
:D Python & Ruby are like Ubuntu and Kubuntu, Its very hard to compete though.

but still interest to do it. how can we start?

Can i start with my latest find, the roman converter "CCXCIV" to 294 with one line of python? :D

we can start giving challenge examples each others and compete it? how do u think?

Mark
Comment by Ei Maung on October 17, 2009 at 5:02pm
@Mark
>> do we interest to start language wars in another thread? I am on python side btw :D

OK, let go ahead. I'm on Ruby side... :D
Comment by Ei Maung on October 17, 2009 at 5:00pm
@Ko Myint Kyaw Thu

FYI:

.NET Framework version 3.0 and later contain WPF (Windows Presentation Foundation) which is build on DirectX. It will provide hardware acceleration for Transparency, Gradient and other UI features and use Direct3D to render UI.

It also offer a new markup language XAML. So you can transform your app to Silverlight which will run inside web browser.

You already familiar with DirectX, Direct3D and Flash. Right? You might love WPF... :)
Comment by Myint Kyaw Thu on October 17, 2009 at 4:40pm
>> very true, .net is too big, and lots of dependencies,

@Ko Mark, last time I update my flash, it's 10 sec and it's up and running before I know it! No wonder 90% of users has latest flash version!
Comment by Myint Kyaw Thu on October 17, 2009 at 4:39pm
Ko Ei Maung ရဲ႔ဒီ post ကိုအႀကိမ္ေပါင္းမ်ားစြာ ဖတ္ပါတယ္။ ဖတ္ၿပီးတိုင္း ဟုတ္လိုက္ေလ ဆိုၿပီး အရမ္းသေဘာက်ပါတယ္။ ဘာေၾကာင့္ဆို Ko Ei Maung လိုဘဲ ကိုယ္တိုင္ framework ေတြေရးရတာ သေဘာက်ပါတယ္။ ကိုယ္ပိုင္ framework ေတြ library functions ေတြ စုထားရင္ ေနာက္ပိုင္း program ေရးရတာ အရမ္းသက္သာပါတယ္။ ဒါေပမဲ့၊ program ေရးဖို႔ hardcore programmer တေယာက္ျဖစ္စရာ မလိုပါဘူး။ IDE user အေနနဲ႔လဲ အရမ္းအသုံး၀င္တဲ့ program ေျမာက္မ်ားစြာ ေရးႏိုင္ပါတယ္။ super hardcore programmer ျဖစ္ၿပီး ဘာမွေရေရရာရာ မေရးဘဲ၊ တို႔လို႔တန္းလန္းေတြ မ်ားေနရင္ အလကားဘဲျဖစ္မွာပါ။ ဒါေၾကာင့္၊ ကိုယ္တိုင္ေတာ့ framework ေတြကို မုန္းတယ္၊ မသုံးဘူး။ Framework programmer ေတြကိုေတာ့ လက္ခံေပးႏိုင္တယ္ (dotNet framework မသုံးဘူးဆိုရင္ေပါ့၊ သုံးရင္လဲ XP မွာပါတဲ့ version သုံးၾကပါ။ ကိုယ့္ program ကိုလူတိုင္းသုံးႏိုင္ေအာင္ေပါ့ :P )

© 2014   Created by Ko Chit.

Badges  |  Report an Issue  |  Terms of Service