工作忙,學習也忙。
1、Ruby on Rails
前陣子看了一下Ruby on Rails,不禁為其深深折服,為Ruby,也為Rails。
照著Four Days on Rails做了一遍,雖然對Ruby不甚熟悉,不過一路下來感覺非常輕松,在搞明白:xxx和"xxx"是同一個意思以后,終于能看懂大部分代碼了,也為這種語法叫好,要知道很多時候引號并不好用,當出現(xiàn)嵌套的時候。(注:在Ruby里,"hello, #{user[:name]}"表示把user["name"]的值放到那個引號里面,這樣做可以不仔細去考慮是不是使用單引號)
接著試了一下typo,一個ruby寫的blog程序,看到它具有登錄功能,而在4 days中并沒有看到,于是找了相關(guān)資料,原來Rails中已經(jīng)有這東西了,簡單查看了文檔以后,就為4 days中的那個演示項目加上了登錄功能,前后不過十來分鐘。
這樣看來,一個人要做一個blog程序,大概2-3小時就夠了,包括編寫數(shù)據(jù)庫模式、生成管理者使用的MVC結(jié)構(gòu)(具有添加修改刪除等功能)、添加登錄功能,在此基礎(chǔ)上再生成一個Controller,簡單修改就能改成供其它用戶使用的閱讀界面,再稍費點神就能加上評論功能了。當然離標準的blog程序還有段距離,比如還不支持RSS,不過自己用來寫點東西記點筆記什么的,足夠用了。
2、Ajax on Rails
接著學習了Ajax on Rails,非常好用的東東,文檔并不是很多,簡單看了一下,覺得離我的想法還有點距離。我希望是可以實現(xiàn)像Gmail一樣,讀取一些變量過來,在頁面上動態(tài)生成元素,而不是讀取其它頁面并把其中的元素替換掉當前頁面上的元素,或者是添加到當前頁面上這么簡單。我查看過Gmail界面的源代碼,好像是使用過混淆器,不過還是可以看出來,它是從服務(wù)端讀取一些變量,讀到客戶端再把它轉(zhuǎn)成可視的元素。
微軟的space.msn.com在注冊時,有一個驗證碼,當你看不清時可以點擊右邊的按鈕再換一個驗證碼,這時只會刷新驗證碼而不用刷新整個頁面,這種東西使用Ajax on Rails應(yīng)該很輕松就可以完成。不過我還不知道在Rails中如何生成驗證碼呢,應(yīng)該是使用其它的庫來生成吧,有空查一下看看。
3、Ruby and Rails
Ruby的語法對于我這樣的初學者(實際上并未正式學習)來說,有些地方理解起來還真有點難,不過它的代碼看起來卻很舒服,簡潔美觀,似乎很多語法都是為了美觀,當然滿篇的end除外。
Rails同樣給我簡潔美觀的印象,使用簡單,沒有什么廢話,視圖如果不修改的話,甚至可以不生成出來。
不知道效率如何,不過聽說Ruby比Python運行效率要高,豆瓣使用Python能做出來,我想使用Ruby應(yīng)該也可以做出能夠接受的東西。
有空要好好學一下Ruby,為了Rails。
4、asgard
最近實在是太忙了,asgard項目起了個頭又懶得動了,許多情況下使用C++都意味著要寫很多代碼,目前完成了異步回調(diào)函數(shù)的泛類型匹配,在編寫調(diào)用函數(shù)的適配器時,雖然已經(jīng)想出了解法,只是要寫大量的模板,天天在模板堆里頭都是痛的,只好先放一放了。
注:
1、上面提到的“異步回調(diào)函數(shù)的泛類型匹配”,指的是下面的做法:
void callback (int, short, const char*);
Method <string(in<char>, in<char>)> method;
method.async_call ('a', 'b', callback);
由于char可以轉(zhuǎn)型到int, short,而out<string>可以轉(zhuǎn)型到const char*,所以讓它支持這種“泛”類型匹配也是理所當然的了,這個東西已經(jīng)完成了。
2、“調(diào)用函數(shù)的適配器”是更復(fù)雜的一個東西,用在服務(wù)器端:
Method <void(inout<Buffer<char> >, in<string>)> my_strcat;
my_strcat.setMethod (Adapter <void(Default<1>, Default<2>, ContainerSize<1>)> (strncat) );
這是最終簡化了的形式,比上次所說的簡單了不少,因為很多東西是可以推導出來的,這也是測試證明可以實現(xiàn)的,一個簡單的修改就是把Adapter從類改為一個函數(shù),由于模板函數(shù)的參數(shù)類型可以推導出來,所以省去了strncat函數(shù)類型的描述。
實際上是把char* strncat(char*, const char*, size_t)匹配給上面這個method,Adapter承擔解釋角色。
它的函數(shù)類型的模板參數(shù)中,void可以推導為out<void>,strcat的調(diào)用結(jié)果賦給out<void>,可以不理會,實際上是使用偏特化來忽略它的,因為我的vector <IParameter*>中根本不包括out<void>這個對象。
后面的Default<1>表示使用默認的轉(zhuǎn)換器,即直接把Buffer<char>對象轉(zhuǎn)成char*類型,由于Buffer<T>中實現(xiàn)了operator T*,這個轉(zhuǎn)換不成問題,下一個是Default<2>,在in<string>中也實現(xiàn)了operator const char*,所以這個轉(zhuǎn)換也很順利,再下一個是ContainerSize<1>表示從Buffer<char>對象中取容器的大小,這也是個模板。
目前一共實現(xiàn)了3個模板,Default<int>默認轉(zhuǎn)換,Size<int>取sizeof,ContainerSize取容器大小。
寫模板既有挑戰(zhàn),又有困難,有時甚至有放棄的想法,甚至有朋友笑話說,人家都動態(tài)語言了,你還在使用這種宏一樣的語言。我也只好一笑置之,這樣的功能在動態(tài)語言里多么容易呀,的確在做一種不不明智的事。。。