国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

編程語言的變遷

atinosun / 3451人閱讀

摘要:本文檔試圖以一個問題的解決方案為主線,描繪出目前常用技術(shù)的變遷及使用。腳本語言興起隨著互聯(lián)網(wǎng)的發(fā)展,編程語言興起,帶動了腳本語言的快速發(fā)展如今,腳本語言也可以和好的實現(xiàn)后端邏輯,,前端逐漸走向后端,后端也逐漸靠近前端,技術(shù)又開始了新的發(fā)展。

引言

做技術(shù)幾年下來,要不停跟著技術(shù)的變革而學習,有時會出現(xiàn)“只見樹木,不見森林”的情況,在項目實戰(zhàn)中,片面的技術(shù)方案可能會因為考慮不全面而導致后期擴展困難甚至引發(fā)bug。本文檔試圖以一個問題的解決方案為主線,描繪出目前常用技術(shù)的變遷及使用。

問題提出

剛學編程的時候,試圖寫一個下載程序:給定一個URL網(wǎng)址,下載并保存為文件。
基本的C語言知識,加上網(wǎng)上找的資料,就可以完成這個功能。

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;
}

這個是我上學時寫的程序,現(xiàn)在看起來有很多問題(都有什么問題?),不過基本的功能算是實現(xiàn)了。如果能把里面的string全換成char*來實現(xiàn),說明C語言考試能過。

這個程序體現(xiàn)了結(jié)構(gòu)化程序編程的特點:順序,循環(huán),分支以及函數(shù)

問題進化:多線程

但是實際工作中不可能如此簡單,比如能不能同時下載多個文件,或者將一個文件分片下載?(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;
}

到這里還遠沒有結(jié)束,比如如何控制并發(fā)的線程數(shù)量,如果讓多個下載線程寫入同一個文件(線程互斥?),甚至是多進程的配合等。
這個例子中,問題演變?yōu)槿绾巫孋PU同時做更多的工作?這其實是技術(shù)演變的一個主線,如何讓高速的CPU和低速的IO(磁盤,網(wǎng)絡等)配合的更高效。

問題進化:UserInterface

自從Windows系統(tǒng)出來后,客戶端編程再也不像前面那樣簡單直接了。
總要給用戶一個東西,讓他們點吧,而我們的程序不可能自己去處理所有屏幕的點擊事件,來判斷用戶到底點了哪個pixcel,它又屬于哪一個button。這些通過和操作系統(tǒng)配合,應用程序能很好的完成。

我們想給下載工具寫一個界面,比如做一個PC版的,讓它能在電腦上跑起來,就像迅雷一樣。

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個參數(shù)
    wndClass.lpfnWndProc = WndProc;

    RegisterClass(wndClass);
    HWND hWnd = CreateWindow(wndClass, ...);
    ShowWindow(hWnd, SW_SHOW);
    
    MSG msg = {};
    while (GetMessage(&msg))    // 這里面有一個WaitSemaphore
    {
        TranslateMessage(&msg);
        DispatchMessage(&msg);
    }
    return 0;
}    

上例中引入了一個重要的概念Callback,意思就是你等著,我來調(diào)你
同一個應用,不僅僅是我們的程序來完成功能,和需要和系統(tǒng)配合。連接系統(tǒng)和我們程序的,在這里就是Callback和MSG。還有隱含的消息隊列。

這個消息驅(qū)動模型被Windows發(fā)明出來后,一直用到今天。

當然,Windows程序這樣的寫法太土了,WndProc里面的switch夸張的分支能有上千個分支,(Windows的資源管理代碼中,分支就上千個)。
于是乎,各種Framework就跳出來解救廣大程序員了,什么MFC,ATL、WTL之類。

比如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的實現(xiàn)里面,可能是這樣的:

class CMainWindow: public CWindow
{
    // message map
    void OnCreate();
    void OnClose();
    void OnHandler();
    //....
}

其它的系統(tǒng),也隱藏了窗口創(chuàng)建等細節(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,其實就是一個消息處理機制(類比WndProc)。我們需要理解消息,消息隊列及消息處理。

在IOS中,消息隊列別隱藏起來,取而代之的是Delegate模式:

int main(int argc, char * argv[]) {
    @autoreleasepool {
        return UIApplicationMain(argc, argv, nil, NSStringFromClass([NetChatApp class]));
    }
}

UIApplicationMain中,就維護了消息隊列(Run Loop),檢測應用的生命周期,并通過Delegate分發(fā)處理。

腳本語言興起

隨著互聯(lián)網(wǎng)的發(fā)展,Web編程語言興起,帶動了腳本語言的快速發(fā)展;如今,腳本語言也可以和好的實現(xiàn)后端邏輯,Nodejs,前端逐漸走向后端,后端也逐漸靠近前端,技術(shù)又開始了新的發(fā)展。全棧,下一個進階的目標。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/86009.html

相關文章

  • 云時代,程序員將面臨分化

    摘要:價值云時代,云計算成為了水電氣般的基礎設施,必然帶來程序員的進一步分化。如果說,云時代的云公司們提供的基礎設施和技術(shù)服務將是一輛車的發(fā)動機,那么面向業(yè)務開發(fā)的程序員其實提供的就是變速箱。 showImg(https://segmentfault.com/img/remote/1460000006923761?w=1024&h=576); 曾經(jīng)翻譯了一篇文章《現(xiàn)在云戰(zhàn)爭(真的)開始了》 ...

    LoftySoul 評論0 收藏0
  • Docker 架構(gòu)私有云機遇和挑戰(zhàn)

    摘要:說起,必須要介紹是什么東西,為什么中小企業(yè)私有云適合使用。看一下現(xiàn)在的架構(gòu)圖開個玩笑。上面這四點導致我們必須要統(tǒng)一架構(gòu),最終把整個業(yè)務系統(tǒng)遷移到基于的類似于的私有云的平臺。 本文系 ArchSummit 大會 CODING 工程師王振威演講實錄。 showImg(https://dn-coding-net-production-pp.qbox.me/c2f81423-54b9-4a7b...

    bang590 評論0 收藏0
  • 前端框架模式變遷

    摘要:現(xiàn)在在前端的框架都是的模式,還有像和之類的變種獨特的單向數(shù)據(jù)流框架。只要將數(shù)據(jù)流進行規(guī)范,那么原來的模式還是大有可為的。我們可以來看一下,框架的圖示從圖中,我們可以看到形成了一條到,再到,之后是的,一條單向數(shù)據(jù)流。 前言 前端框架的變遷,體系架構(gòu)的完善,使得我們只知道框架,卻不明白它背后的道理。我們應該抱著一顆好奇心,在探索框架模式的變遷過程中,體會前人的一些理解和思考 本篇將講述的是...

    ssshooter 評論0 收藏0
  • TiEye:Region 信息變遷歷史可視化工具 | TiDB Hackathon 2018 優(yōu)秀項

    摘要:本文作者是矛盾螺旋隊的成員劉瑋,他們的項目在中獲得了三等獎。博康負責后端框架以及相應的修改,我負責后端查詢,振靖負責前端可視化。次日返回賽場,抽簽確定時間,最終為第四個出場。 本文作者是矛盾螺旋隊的成員劉瑋,他們的項目?TiEye?在 TiDB Hackathon 2018 中獲得了三等獎。TiEye 是?Region 信息變遷歷史可視化工具,通過 PD記錄 Region 的Split...

    sevi_stuo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<