ကြ်န္ေတာ္ ေနာက္ဆံုး ေရးခဲ့တဲ့ - 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: 180

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 )

Latest Activity

nyiminthit posted a status
"TPlink-TD8816 modern Router ကို config လုပ္ခ်င္လို ့ပါ အင္တာနက္လိုင္းမတက္လို ့တိုင္ပတ္ေနလို ့ကူညီၾကပါဦး ခင္မ်ာ"
11 hours ago
Htet Oo Zaw replied to GaaRa's discussion ႈွYatanarpon ADSL ႏွင့္ Elite Fiber(FTTX) အင္တာနက္လိုင္း ႏွစ္လိုင္းကုိ load balancing လုပ္ခ်င္လို.ပါ
14 hours ago
Htet Oo Zaw updated their profile
16 hours ago
zaw moe tun updated their profile
21 hours ago
Profile Iconေဇာ္ထြန္း ေနျပည္ေတာ္, zaw lin tun, Lina and 185 more joined MyanmarITPro - A Social Network for Myanmar IT Professionals
yesterday
Phyo Phyo posted a status
"I want to know banking network .How to operate network."
Thursday
Phyo Phyo updated their profile
Thursday
kohla and Nay Min are now friends
Wednesday
kyawzinlatt shared manawphyulay's blog post on Facebook
Jul 22
Hteinlinaung liked Aung Myint Tun's blog post အင္တာနက္သံုးရင္း တစ္ေန႔ကို $160 ရမည့္ Online ေငြရွာနည္း
Jul 20
လြဲေန replied to Kam's discussion Kerio winrout firewall တင္ရင္Blue screen တက္တယ္. Why? in the group Ask MITP
Jul 19
kglay@it posted a status
Jul 12

© 2014   Created by Ko Chit.

Badges  |  Report an Issue  |  Terms of Service