摘要:本文檔試圖以一個(gè)問(wèn)題的解決方案為主線,描繪出目前常用技術(shù)的變遷及使用。腳本語(yǔ)言興起隨著互聯(lián)網(wǎng)的發(fā)展,編程語(yǔ)言興起,帶動(dòng)了腳本語(yǔ)言的快速發(fā)展如今,腳本語(yǔ)言也可以和好的實(shí)現(xiàn)后端邏輯,,前端逐漸走向后端,后端也逐漸靠近前端,技術(shù)又開(kāi)始了新的發(fā)展。
引言
做技術(shù)幾年下來(lái),要不停跟著技術(shù)的變革而學(xué)習(xí),有時(shí)會(huì)出現(xiàn)“只見(jiàn)樹(shù)木,不見(jiàn)森林”的情況,在項(xiàng)目實(shí)戰(zhàn)中,片面的技術(shù)方案可能會(huì)因?yàn)榭紤]不全面而導(dǎo)致后期擴(kuò)展困難甚至引發(fā)bug。本文檔試圖以一個(gè)問(wèn)題的解決方案為主線,描繪出目前常用技術(shù)的變遷及使用。
問(wèn)題提出剛學(xué)編程的時(shí)候,試圖寫(xiě)一個(gè)下載程序:給定一個(gè)URL網(wǎng)址,下載并保存為文件。
基本的C語(yǔ)言知識(shí),加上網(wǎng)上找的資料,就可以完成這個(gè)功能。
std::string DownloadFile(const std::string& url) { // Download code:use while ... } bool SaveFile(const std::string& fileName, const std::string& content) { // Save file code:check success ... } int main(int argc, char* argv[]) { std::string url = argv[1]; std::string content = DownloadFile(url); SaveFile(content); return 0; }
這個(gè)是我上學(xué)時(shí)寫(xiě)的程序,現(xiàn)在看起來(lái)有很多問(wèn)題(都有什么問(wèn)題?),不過(guò)基本的功能算是實(shí)現(xiàn)了。如果能把里面的string全換成char*來(lái)實(shí)現(xiàn),說(shuō)明C語(yǔ)言考試能過(guò)。
這個(gè)程序體現(xiàn)了結(jié)構(gòu)化程序編程的特點(diǎn):順序,循環(huán),分支以及函數(shù)。
問(wèn)題進(jìn)化:多線程但是實(shí)際工作中不可能如此簡(jiǎn)單,比如能不能同時(shí)下載多個(gè)文件,或者將一個(gè)文件分片下載?(Flashget,迅雷)
這就引入了多線程:
void DownloadThread(void* param) { if (param) { std::string url = (const char*)param; SaveFile(DownloadFile(url)); DestroySemaphore(); } } int main(int argc, char* argv[]) { std::string urllist = argv[1]; std::vector ulist = ParseUrlList(urllist); for (auto it = ulist.begin(); it != ulist.end(); it++) { int pThread = CreateThread(DownloadThread, it->str()); int pSem = CreateSemaphore(); InitSemaphore(pSem); // save thread context and init sem ... } // 線程同步 WaitAllSemaphore(); return 0; }
到這里還遠(yuǎn)沒(méi)有結(jié)束,比如如何控制并發(fā)的線程數(shù)量,如果讓多個(gè)下載線程寫(xiě)入同一個(gè)文件(線程互斥?),甚至是多進(jìn)程的配合等。
這個(gè)例子中,問(wèn)題演變?yōu)槿绾巫孋PU同時(shí)做更多的工作?這其實(shí)是技術(shù)演變的一個(gè)主線,如何讓高速的CPU和低速的IO(磁盤(pán),網(wǎng)絡(luò)等)配合的更高效。
自從Windows系統(tǒng)出來(lái)后,客戶端編程再也不像前面那樣簡(jiǎn)單直接了。
總要給用戶一個(gè)東西,讓他們點(diǎn)吧,而我們的程序不可能自己去處理所有屏幕的點(diǎn)擊事件,來(lái)判斷用戶到底點(diǎn)了哪個(gè)pixcel,它又屬于哪一個(gè)button。這些通過(guò)和操作系統(tǒng)配合,應(yīng)用程序能很好的完成。
我們想給下載工具寫(xiě)一個(gè)界面,比如做一個(gè)PC版的,讓它能在電腦上跑起來(lái),就像迅雷一樣。
LRESULT CALLBACK WndProc( //WndProc名稱可自由定義 HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam ) { switch (uMsg) { case WM_CREATE: OnCreate(); break; case WM_CLOSE: OnClose(); break; case WM_DOWNLOAD: // 可以自定義消息 OnDownload(wParam, lParam); break; case WM_STOP_DOWNLOAD: OnStopDownload(); break; case WM_DOWNLOAD_PROGRESS: OnDownloadProgress(); break; // 此處還有各種消息 ... case WM_QUIT: PostQuitMessage(0); // 通知該線程的GetMessage,可以退出了; break; default: DefWndProc(hwnd, uMsg, wParam, lParam); } return 0; } int main(int argc, char* argv[]) { WNDCLASS wndClass = {}; wndClass.style = WS_WINDOW; wndClass.hIcon = HICON_NONE; ... // 大約1x個(gè)參數(shù) wndClass.lpfnWndProc = WndProc; RegisterClass(wndClass); HWND hWnd = CreateWindow(wndClass, ...); ShowWindow(hWnd, SW_SHOW); MSG msg = {}; while (GetMessage(&msg)) // 這里面有一個(gè)WaitSemaphore { TranslateMessage(&msg); DispatchMessage(&msg); } return 0; }
上例中引入了一個(gè)重要的概念Callback,意思就是你等著,我來(lái)調(diào)你。
同一個(gè)應(yīng)用,不僅僅是我們的程序來(lái)完成功能,和需要和系統(tǒng)配合。連接系統(tǒng)和我們程序的,在這里就是Callback和MSG。還有隱含的消息隊(duì)列。
這個(gè)消息驅(qū)動(dòng)模型被Windows發(fā)明出來(lái)后,一直用到今天。
當(dāng)然,Windows程序這樣的寫(xiě)法太土了,WndProc里面的switch夸張的分支能有上千個(gè)分支,(Windows的資源管理代碼中,分支就上千個(gè))。
于是乎,各種Framework就跳出來(lái)解救廣大程序員了,什么MFC,ATL、WTL之類(lèi)。
比如ATL
CApp theApp; int Run() { CMessageLoop loop; theApp.AddMessageLoop(loop); CMainWindow wnd; wnd.Create(); wnd.ShowWindow(); loop.Run(); theApp.RemoveMessageLoop(); } int main(int argc, char* argv[]) { theApp.Init(); int nRet = Run(); theApp.term(); return 0; }
在CMainWindow的實(shí)現(xiàn)里面,可能是這樣的:
class CMainWindow: public CWindow { // message map void OnCreate(); void OnClose(); void OnHandler(); //.... }
其它的系統(tǒng),也隱藏了窗口創(chuàng)建等細(xì)節(jié),在系統(tǒng)層面,就封裝好了,方便程序員使用。
比如Android:
public class MyWindow extends Activity { private Handler mMainHandler = new Handler() { @Override public void handleMessage(Message msg) { switch (msg.what) { case XXX: onXXX(); break; default: break; } } } protected void onCreate(Bundle savedInstanceState) { // } protected void onDestroy() { // } }
Android中的Handler,其實(shí)就是一個(gè)消息處理機(jī)制(類(lèi)比WndProc)。我們需要理解消息,消息隊(duì)列及消息處理。
在IOS中,消息隊(duì)列別隱藏起來(lái),取而代之的是Delegate模式:
int main(int argc, char * argv[]) { @autoreleasepool { return UIApplicationMain(argc, argv, nil, NSStringFromClass([NetChatApp class])); } }
UIApplicationMain中,就維護(hù)了消息隊(duì)列(Run Loop),檢測(cè)應(yīng)用的生命周期,并通過(guò)Delegate分發(fā)處理。
腳本語(yǔ)言興起隨著互聯(lián)網(wǎng)的發(fā)展,Web編程語(yǔ)言興起,帶動(dòng)了腳本語(yǔ)言的快速發(fā)展;如今,腳本語(yǔ)言也可以和好的實(shí)現(xiàn)后端邏輯,Nodejs,前端逐漸走向后端,后端也逐漸靠近前端,技術(shù)又開(kāi)始了新的發(fā)展。全棧,下一個(gè)進(jìn)階的目標(biāo)。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/86009.html
摘要:價(jià)值云時(shí)代,云計(jì)算成為了水電氣般的基礎(chǔ)設(shè)施,必然帶來(lái)程序員的進(jìn)一步分化。如果說(shuō),云時(shí)代的云公司們提供的基礎(chǔ)設(shè)施和技術(shù)服務(wù)將是一輛車(chē)的發(fā)動(dòng)機(jī),那么面向業(yè)務(wù)開(kāi)發(fā)的程序員其實(shí)提供的就是變速箱。 showImg(https://segmentfault.com/img/remote/1460000006923761?w=1024&h=576); 曾經(jīng)翻譯了一篇文章《現(xiàn)在云戰(zhàn)爭(zhēng)(真的)開(kāi)始了》 ...
摘要:說(shuō)起,必須要介紹是什么東西,為什么中小企業(yè)私有云適合使用??匆幌卢F(xiàn)在的架構(gòu)圖開(kāi)個(gè)玩笑。上面這四點(diǎn)導(dǎo)致我們必須要統(tǒng)一架構(gòu),最終把整個(gè)業(yè)務(wù)系統(tǒng)遷移到基于的類(lèi)似于的私有云的平臺(tái)。 本文系 ArchSummit 大會(huì) CODING 工程師王振威演講實(shí)錄。 showImg(https://dn-coding-net-production-pp.qbox.me/c2f81423-54b9-4a7b...
摘要:現(xiàn)在在前端的框架都是的模式,還有像和之類(lèi)的變種獨(dú)特的單向數(shù)據(jù)流框架。只要將數(shù)據(jù)流進(jìn)行規(guī)范,那么原來(lái)的模式還是大有可為的。我們可以來(lái)看一下,框架的圖示從圖中,我們可以看到形成了一條到,再到,之后是的,一條單向數(shù)據(jù)流。 前言 前端框架的變遷,體系架構(gòu)的完善,使得我們只知道框架,卻不明白它背后的道理。我們應(yīng)該抱著一顆好奇心,在探索框架模式的變遷過(guò)程中,體會(huì)前人的一些理解和思考 本篇將講述的是...
摘要:本文作者是矛盾螺旋隊(duì)的成員劉瑋,他們的項(xiàng)目在中獲得了三等獎(jiǎng)。博康負(fù)責(zé)后端框架以及相應(yīng)的修改,我負(fù)責(zé)后端查詢,振靖負(fù)責(zé)前端可視化。次日返回賽場(chǎng),抽簽確定時(shí)間,最終為第四個(gè)出場(chǎng)。 本文作者是矛盾螺旋隊(duì)的成員劉瑋,他們的項(xiàng)目?TiEye?在 TiDB Hackathon 2018 中獲得了三等獎(jiǎng)。TiEye 是?Region 信息變遷歷史可視化工具,通過(guò) PD記錄 Region 的Split...
閱讀 867·2023-04-26 00:11
閱讀 2667·2021-11-04 16:13
閱讀 2116·2021-09-09 09:33
閱讀 1484·2021-08-20 09:35
閱讀 3837·2021-08-09 13:42
閱讀 3615·2019-08-30 15:55
閱讀 1075·2019-08-30 15:55
閱讀 2229·2019-08-30 13:55