本來(lái)每年都要寫(xiě)一篇年經(jīng)帖來(lái)提高一下知名度的,但是最近因?yàn)樽鯣acUI太興奮,竟然把這件事情給忘了,實(shí)在是罪過(guò)。
如果要說(shuō)我2012年做過(guò)的什么事情最重要,那當(dāng)然要屬開(kāi)發(fā)了GacUI(Home Page, Codeplex, Github)和創(chuàng)建了粉絲群(啊哈哈)了吧。博客到現(xiàn)在還有三個(gè)坑沒(méi)填完,分別是那個(gè)已經(jīng)坑了好久、大家都要看、但是我卻不知道要寫(xiě)什么的《C++使用技巧》,還有兩個(gè)大家不怎么想看的《可配置語(yǔ)法分析器開(kāi)發(fā)紀(jì)事》和《GacUI與設(shè)計(jì)模式》。
關(guān)于GacUI,我已經(jīng)在微博上做了許多廣告,也有一些人開(kāi)始嘗試使用它了。目前GacUI還處于一個(gè)湊合著能用的beta狀態(tài),我在接下來(lái)的很長(zhǎng)一段時(shí)間內(nèi)應(yīng)該會(huì)繼續(xù)update它。我的本意是要把WPF那么精妙的設(shè)計(jì)給山寨到C++上面來(lái),從而結(jié)束非得用MFC才能正常開(kāi)發(fā)GUI的日子。而且因?yàn)橹拔矣肅#的WinForm開(kāi)發(fā)IDE太蛋疼了,parser需要寫(xiě)兩遍(編譯器一遍,IDE一遍,語(yǔ)言還不一樣),所以我在設(shè)計(jì)GacUI的時(shí)候,質(zhì)量要求就是朝著Visual Studio看齊的。所以大家會(huì)看到我在做GacUI的時(shí)候,文本框就內(nèi)置了高速的著色系統(tǒng),還做了一個(gè)新的parser來(lái)產(chǎn)生嚴(yán)格的parser或者松散的parser,分別給編譯器和IDE使用。然后我用這個(gè)parser寫(xiě)了一個(gè)xml和json的庫(kù),最后在昨天還update了一下Linq to C++,把我看得不順眼的東西都干掉,于是我也擁有了一個(gè)Linq to Xml for C++的庫(kù)了。
但是GacUI還是有很多東西要做。我腦子里一直有一個(gè)清晰的路線(xiàn)圖,而且這個(gè)路線(xiàn)圖是直接朝著目標(biāo)前進(jìn)的:做一個(gè)C++的GUI庫(kù),順便給一個(gè)類(lèi)似Expression Blend那樣子的東西,然后那個(gè)框架還可以為我以后開(kāi)發(fā)語(yǔ)言,或者給現(xiàn)有的語(yǔ)言做IDE。所以為了達(dá)到這個(gè)目標(biāo),我至少要給GacUI的控件和對(duì)象模型做反射。為了讓大家可以使用,我還得準(zhǔn)備一個(gè)看起來(lái)跟MSDN很像的文檔。因此路線(xiàn)圖就是(粗體的部分已經(jīng)完成了)
1. 開(kāi)發(fā)控件庫(kù)
2. 擁有一套生成Release的工具鏈,包括parser生成器、文檔生成器、各種代碼生成器等
3. 有一個(gè)小巧玲瓏簡(jiǎn)單好用的XML庫(kù)
4. 可以讀PDB把GacUI的對(duì)象聲明都拿到手
5. 利用PDB和GacUI的源代碼里面的XML注釋生成文檔
6. 用一個(gè)類(lèi)似C#那樣子的語(yǔ)法來(lái)給GacUI“聲明”一個(gè)對(duì)象模型,讓他可以被反射,也可以用來(lái)生成各種語(yǔ)言用的接口,特別是動(dòng)態(tài)語(yǔ)言例如javascript和python的
7. 把PDB的內(nèi)容和對(duì)象模型結(jié)合起來(lái),生成C++用的反射代碼
8. 利用反射代碼,設(shè)計(jì)一個(gè)GUI的XML(或者別的什么東西)表示,從而實(shí)現(xiàn)動(dòng)態(tài)加載窗口
9. 制作一個(gè)長(zhǎng)得和操作模式都跟Visual Studio差不多的多文檔編輯框架
10. 用上面的框架開(kāi)發(fā)一個(gè)GUI編輯器,用來(lái)拖控件生成xml+資源,就可以嵌入C++的exe,或者提供給腳本語(yǔ)言使用了
11. 提供一個(gè)腳本語(yǔ)言,作為可選的插件,來(lái)簡(jiǎn)化復(fù)雜GUI的開(kāi)發(fā)
12. 給這個(gè)語(yǔ)言提供一個(gè)IDE
大家可以看到,這就是為什么我最近要花時(shí)間做著色、parser生成器、用parser生成器來(lái)生成xml和json的庫(kù)的parsing部分、做一個(gè)linq to C++并且讓xml庫(kù)直接支持就像C#的linq to xml一樣。雖然看起來(lái)這些東西跟GacUI本身毫無(wú)關(guān)系,但是實(shí)際上為了實(shí)現(xiàn)那個(gè)復(fù)雜又得自動(dòng)生成不然寫(xiě)到孩子出來(lái)還人肉不完的反射代碼生成,一定要有配套的基礎(chǔ)設(shè)施才行。
關(guān)于粉絲群,因?yàn)槲壹尤氲拇蟛糠志幊虆^(qū)最后都癟了,所以本來(lái)我并沒(méi)有創(chuàng)建一個(gè)群用來(lái)交流技術(shù)的想法。不過(guò)因?yàn)槟橙河颜f(shuō)找不到人研究我以前的代碼的一篇回復(fù),我還是創(chuàng)建了這個(gè)群。本來(lái)群只有100人的,但是有兩個(gè)人贊助了一下,瞬間變成了500人群。所以以后不斷的有人進(jìn)來(lái)的時(shí)候我就再也不需要踢掉不說(shuō)話(huà)的人了。很快群里就開(kāi)始熱烈的討論起問(wèn)題,經(jīng)常討論的那么十幾二十個(gè)人也這么固定下來(lái)了。這個(gè)群和別的群不一樣的地方在于,所有問(wèn)傻逼問(wèn)題和求大作業(yè)的全部被我和鸛貍猿們一個(gè)不留的干掉了,啊哈哈哈哈。
由于我在cppblog廣告的關(guān)系,加入這個(gè)群的人大部分還是做C++的,和S1那群做web的平時(shí)跟技術(shù)有關(guān)的話(huà)題完全不同,對(duì)待某些人生底線(xiàn)問(wèn)題(譬如說(shuō)大括號(hào)要不要換行等)的態(tài)度也是完全不同。當(dāng)然偶爾有人經(jīng)不住每天幾千個(gè)消息的沖擊退群了,但是群的熱烈程度還是一點(diǎn)也沒(méi)有消減。
關(guān)于C++實(shí)用技巧,由于我自詡是一個(gè)做C++基礎(chǔ)類(lèi)庫(kù)的人,對(duì)待C++各種奇技淫巧的態(tài)度自然也是不一樣的。盡管大家都說(shuō)C++學(xué)起來(lái)很難,坑很多,模板根本看不懂,析構(gòu)函數(shù)沒(méi)寫(xiě)程序函數(shù)經(jīng)常要爛掉之類(lèi)的,不過(guò)我的觀點(diǎn)還是很明確的——其實(shí)C++有很多難以理解的功能,都是給寫(xiě)基礎(chǔ)類(lèi)庫(kù)準(zhǔn)備的。只要程序員們不要本著“我一定要看懂類(lèi)庫(kù)怎么寫(xiě)才用”的這種無(wú)聊觀點(diǎn)的話(huà),其實(shí)壓力并不會(huì)那么大。大多數(shù)人覺(jué)得C++難,但其實(shí)難的部分他做項(xiàng)目大概也是用不上的,本質(zhì)原因還是不夠淡定導(dǎo)致。
說(shuō)到這里我就想起了以前跟人家討論的,為什么C#用起來(lái)就那么舒服呢?很重要的一點(diǎn)其實(shí)是,因?yàn)檫x擇少,所以連煩惱都沒(méi)有了。反正事情都能完成,但是方法只有一種的話(huà),你永遠(yuǎn)都不需要去比較或者糾結(jié)說(shuō),究竟要用什么樣的方法來(lái)實(shí)現(xiàn)。而且一個(gè)自帶垃圾收集器+泛型+函數(shù)式編程+continuation的語(yǔ)言,語(yǔ)法懂得少也可以用,語(yǔ)法懂得多用起來(lái)還特別省事,這一點(diǎn)的確比C++要好得多。回想起2002在CSDN那個(gè)著名的對(duì)垃圾收集器的大討論,ajoo有一點(diǎn)說(shuō)得很好,有沒(méi)有GC,設(shè)計(jì)出來(lái)的架構(gòu)都大不一樣。想想原因其實(shí)也很簡(jiǎn)單,語(yǔ)言一旦帶有GC的話(huà),通常都會(huì)對(duì)內(nèi)存做出嚴(yán)格的控制,因此你想干掉一個(gè)對(duì)象就只有一種方法——等他去死了(C#的IDisposable跟這個(gè)其實(shí)沒(méi)什么關(guān)系)。因此那些C++里面很執(zhí)著的誰(shuí)創(chuàng)建誰(shuí)刪除啊,COM的什么引用計(jì)數(shù)啊,這些亂七八糟的東西統(tǒng)統(tǒng)就沒(méi)有了。你可以不顧一起的創(chuàng)建各種細(xì)粒度對(duì)象,不斷地創(chuàng)建各種接口,而根本不用擔(dān)心這些對(duì)象在死的時(shí)候你要干些什么,不僅做出來(lái)的設(shè)計(jì)干凈,用起來(lái)也省心。
關(guān)于可配置語(yǔ)法分析器開(kāi)發(fā)紀(jì)事,按照計(jì)劃還剩下兩篇,不過(guò)因?yàn)檫@兩篇的內(nèi)容已經(jīng)不怎么重要,所以最近的時(shí)間都用在開(kāi)發(fā)GacUI上面了。等雜事搞完了之后我就補(bǔ)上這部分內(nèi)容。
關(guān)于GacUI與設(shè)計(jì)模式,這個(gè)系列自從寫(xiě)了兩篇文章之后,盡管GacUI都是我一手寫(xiě)出來(lái)的,但是我發(fā)現(xiàn)要整理出那個(gè)架構(gòu)清楚的表達(dá)出來(lái),需要花很多的時(shí)間。為了保證文章的質(zhì)量,我干脆就暫時(shí)停下來(lái)了,一邊推進(jìn)GacUI的開(kāi)發(fā)進(jìn)度,一邊 重新整理。雖然我從來(lái)都只用VC++來(lái)編譯我的代碼,不過(guò)GacUI從一開(kāi)始設(shè)計(jì)架構(gòu)上就有考慮跨平臺(tái)的問(wèn)題,而且我也把對(duì)Windows.h的依賴(lài)也局限在少數(shù)的幾個(gè)cpp文件里,頭文件則完全是沒(méi)有污染的。盡管代碼里面肯定有VC++對(duì)標(biāo)準(zhǔn)作出的一點(diǎn)點(diǎn)人性化修改而垃圾GCC故意不支持從而造成代碼不能再GCC上面編譯,不過(guò)在計(jì)劃上我大概會(huì)在今年的下半年開(kāi)始把代碼修改成讓垃圾GCC也可以編譯GacUI了。
關(guān)于2013年,出去開(kāi)發(fā)GacUI和心目中的那個(gè)腳本引擎,我在2013年最想點(diǎn)的技能樹(shù)就是編譯器的后端知識(shí)了。盡管我在09年的時(shí)候做過(guò)一個(gè)傻逼C語(yǔ)言編譯器,盡管也是編譯成機(jī)器碼,但是都是用最簡(jiǎn)單粗暴的方法來(lái)做的。為了以后的腳本引擎,把這件事情做好,掌握編譯器的后端也就變成必要的事情了。不過(guò)我在這里還是想說(shuō),編譯器的前端知識(shí)也是很重要的。經(jīng)過(guò)設(shè)計(jì)語(yǔ)言的語(yǔ)法的訓(xùn)練,和對(duì)設(shè)計(jì)類(lèi)型系統(tǒng)的訓(xùn)練,不僅可以提高數(shù)學(xué)知識(shí)、提高智商,還可以讓你學(xué)習(xí)新的語(yǔ)言和類(lèi)庫(kù)變得更快。編程都是舉一反三的,并不是直接的針對(duì)他學(xué)習(xí)才是長(zhǎng)遠(yuǎn)看來(lái)最好的方法。
posted on 2013-01-25 06:29
陳梓瀚(vczh) 閱讀(5233)
評(píng)論(12) 編輯 收藏 引用 所屬分類(lèi):
啟示