青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

qiezi的學習園地

AS/C/C++/D/Java/JS/Python/Ruby

  C++博客 :: 首頁 :: 新隨筆 ::  ::  :: 管理 ::
asgard項目已經準備了一段時間了,不過有些基本問題還需要考慮,也有一些是新發現的問題,以及自認為比較好的解決辦法。

通過第2、第4條的仔細研究,已經漸漸完善、明確了動態部分和靜態部分的關系,使得Method包裝類所完成的功能漸漸接近于一個函數,而元信息則脫離具體的對象提升到全局(當然還有些小問題沒有解決)。

1、參數名稱的問題。

為了與SOAP等基于XML的協議兼容,必須開始就把參數名稱考慮在內。

代碼經過C++編譯器編譯以后,類型、變量名稱等都不復存在,唯一留下的是RTTI,顯然不能解決這個問題。所以只能在定義時把它加入。

BEGIN_SERVICE(TestService)
    METHOD (
void(in<int>, inout<string>out<short>), method1, index, info, result);
END_SERVICE()

如果使用這種方式,index, info, result分別表示變量名字,在宏里面轉成字符串,看起來好像不太舒服,而且宏不支持參數個數變化。

BEGIN_SERVICE(TestService)
    METHOD (
void(in<int>, inout<string>out<short>), method1, "(index, info, result)");
    METHOD (
int(in<int>, inout<string>), method2, "result(index, info)");
END_SERVICE()

這種可能稍稍舒服一點,在Method構造函數或其它地方解析這個字符串,賦給各個參數。不過它的缺點是把編譯期應該檢查出來的錯誤,延遲到運行期。如果在編譯期來做,又會使接口描述變得很復雜。

只是為了得到參數的名字,就要增加這么些麻煩。

c++0x只是一個庫的標準,估計XTI也不會加入這些特性,而且c++0x很遙遠,所以暫時以這種方式來做。

暫時的解決辦法:

BEGIN_SERVICE(TestService)
    METHOD (
void(in<int>, inout<string>out<short>), method1);
    METHOD (
int(in<int>, inout<string>), method2);
    BEGIN_SERVICE_DEFINE(TestService)
        METHOD_DEFINE (method1, 
"(index, info, result)", test_func);
        METHOD_DEFINE (method2, 
"result(index, info)"&Test::test_method);
    END_SERVICE_DEFINE()
END_SERVICE()

缺點是參數名稱中的錯誤,要延遲到運行期才能解決掉。

2、服務對象的大小。

如果客戶端要調用其中一個方法,生成一個TestService,則構造成本太高,特別是一個服務中有多個方法的時候。一個服務容納了多個方法,而每個方法包含一個vector,以及各個參數,這還沒考慮以后的擴展。

所以應該修改調用方式,讓它只只需要生成調用所需的最小(少)對象。

這部分考慮還不成熟,暫時可以不管它,而以方法作為考慮的對象。

暫時想到的解決辦法:

Method對象中的parameters容器和各個參數,只在調用operator ()或async_call時,才真正生成出來。

這樣的話,Method對象中僅保存一個空的vector。

甚至這個vector也可以只是一個空指針,當調用那幾個函數時,才生成一個。

暫時把這個過程命名為Create On Call(COC)。

COC的好處是顯而易見的,每個對象將只有8字節,虛表指針+數據對象的指針,“數據對象”是實際調用時才生成的對象,包括參數vector容器、回調函數指針(可能由動態生成一個委托對象,以適應廣泛類型的回調函數)、對象鎖(防止干擾到前一個調用)。初始化成本接近0(虛函數表的初始化忽略不計)。

當調用operator()或async_call時(以下簡稱CALL),將調用create_parameters虛函數,動態生成一個vector。這樣,沒有調用到的Method不會象原來一樣影響到服務對象的構建性能。

這就要求把Method的“元”信息提到全局,當然更符合“元”的本意,原來由服務對象查詢Method以獲得“元”信息的過程,現在看來也是不合理的。

3、in模板可以省略。

in是默認的參數類型,返回值則默認為out類型,這都是不需要明確指定的。

解決辦法:

這個問題是比較好解決的,在InOutTypeTraits模板類中,為各個偏特化版本定義一個type類型,InOutTypeTraits<T>::type的類型為in<T>,InOutTypes<in<T>>::type的類型為in<T>,InOutTypes<inout<T>>::type的類型為inout<T>,InOutTypes<out<T>>::type的類型為out<T>,InList模板類中進行這種轉換。

4、異步調用隊列。

在第2點中介紹道:

每個對象將只有8字節,虛表指針+數據對象的指針,“數據對象”是實際調用時才生成的對象,包括參數vector容器、回調函數指針(可能由動態生成一個委托對象,以適應廣泛類型的回調函數)、對象鎖(防止干擾到前一個調用)。初始化成本接近0(虛函數表的初始化忽略不計)。

提到了對象鎖,這是一種低效的做法,可以使用異步調用隊列來替代它。

解決辦法:

當開始一個調用時,臨時生成上面所說的“數據對象”,交由一個調用隊列去完成。這時,由于Method對象基本不管理數據,所以它成了一個空殼,作用是保存類型信息。

異步調用最好的實現就是整個系統都由異步調用構成,而同步調用是由異步調用模擬而成。原本打算繞過這種方式,用最簡單的方法來做,現在好像又繞回來了。

上面這個做法,很好地把元信息和真實數據分開了,所以打算改成這種結構。

5、全局元信息。

通過第4條的研究,已經使得Method對象成為一個空殼,而“數據對象”在沒有調用時又不生成,使得自省結構必須重新做。

考察了java等語言的自省,也打算把元信息的位置提升到全局,而每個Method對象將只保留一個全局元信息的指針,這樣應該更自然。


(以后遇到的問題只更新到這個文檔中)
posted on 2005-09-24 17:00 qiezi 閱讀(427) 評論(0)  編輯 收藏 引用 所屬分類: C++asgard項目
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲激情一区二区| 在线日韩电影| 午夜视频久久久| 亚洲视频电影在线| 国产乱码精品一区二区三区五月婷| 亚洲女人天堂av| 樱桃视频在线观看一区| 亚洲东热激情| 亚洲毛片av在线| 欧美午夜精彩| 另类图片综合电影| 欧美成人伊人久久综合网| 一本色道久久综合亚洲精品小说 | 美日韩精品免费观看视频| 噜噜噜躁狠狠躁狠狠精品视频 | 亚洲精品一区二区三区四区高清| 亚洲国产成人久久综合| 欧美视频福利| 免费看精品久久片| 欧美日韩在线三级| 久久视频一区二区| 欧美日韩大片一区二区三区| 久久成人免费网| 欧美va天堂| 久久成人18免费网站| 另类图片国产| 欧美一区二区三区在线看| 欧美~级网站不卡| 小嫩嫩精品导航| 欧美精品成人在线| 欧美在线视频观看| 欧美乱大交xxxxx| 久久综合伊人77777蜜臀| 欧美亚州在线观看| 亚洲第一主播视频| 国产在线播放一区二区三区| 亚洲另类一区二区| 一区二区在线观看视频| 亚洲中午字幕| 亚洲一区二区在线看| 蜜臀久久久99精品久久久久久| 久久激情一区| 国产精品久久久久久久午夜片| 欧美激情亚洲国产| 精品福利免费观看| 午夜久久黄色| 午夜在线成人av| 国产精品国产三级国产普通话蜜臀| 欧美福利小视频| 伊人成人开心激情综合网| 亚洲午夜性刺激影院| 一区二区不卡在线视频 午夜欧美不卡在| 久久精品99国产精品酒店日本| 性伦欧美刺激片在线观看| 欧美日韩在线视频首页| 亚洲国产精品悠悠久久琪琪| 亚洲高清激情| 免费不卡视频| 欧美激情va永久在线播放| 影音先锋亚洲精品| 久久久www成人免费精品| 久久只有精品| 亚洲国产日韩欧美在线99| 久久精品一区蜜桃臀影院| 久久久久久久久久久一区 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 你懂的视频欧美| 国内精品视频在线观看| 欧美中文字幕视频在线观看| 欧美一区免费视频| 国产一区二区剧情av在线| 欧美亚洲免费| 蜜桃久久av| 亚洲精品久久7777| 欧美日韩国产黄| 99国内精品| 先锋影音久久| 怡红院精品视频| 欧美大片免费观看在线观看网站推荐| 欧美电影资源| 国产精品99久久久久久久久| 国产精品欧美日韩久久| 欧美在线视屏| 欧美激情在线狂野欧美精品| 一本色道久久88综合亚洲精品ⅰ| 国产精品成人v| 欧美亚洲免费电影| 亚洲第一区在线| 亚洲自拍电影| 亚洲大片精品永久免费| 欧美日韩性视频在线| 午夜亚洲视频| 亚洲国产精彩中文乱码av在线播放| 亚洲视频欧洲视频| 国内一区二区三区| 欧美日本精品一区二区三区| 亚洲综合不卡| 亚洲高清视频一区二区| 亚洲女同同性videoxma| 亚洲大片一区二区三区| 欧美性猛交xxxx乱大交退制版| 久久成人一区二区| 亚洲精品免费一区二区三区| 欧美一区中文字幕| 亚洲精品一级| 国产综合亚洲精品一区二| 欧美日韩亚洲一区三区| 久久激五月天综合精品| 一二三区精品| 亚洲电影激情视频网站| 久久久中精品2020中文| 亚洲一区二区三区免费视频| 在线观看三级视频欧美| 国产精品国产| 欧美日韩国产在线看| 免播放器亚洲一区| 久久成人18免费观看| 在线视频中文亚洲| 亚洲国产精品欧美一二99| 可以看av的网站久久看| 午夜日韩视频| 亚洲图中文字幕| 亚洲免费精彩视频| 亚洲电影在线看| 亚洲电影观看| 伊人成人在线视频| 国产一区91精品张津瑜| 国产精品爽爽爽| 欧美亚州一区二区三区| 欧美日韩午夜剧场| 欧美激情va永久在线播放| 免播放器亚洲一区| 久久综合给合| 久久天天躁夜夜躁狠狠躁2022| 欧美在线二区| 欧美在线观看视频在线 | 99re6这里只有精品| 亚洲人成人一区二区三区| 国产精品乱码| 欧美另类人妖| 免费一区视频| 欧美成人dvd在线视频| 老司机精品久久| 久久影视三级福利片| 美女精品在线| 欧美精彩视频一区二区三区| 欧美电影打屁股sp| 欧美激情亚洲激情| 欧美日韩另类一区| 欧美午夜免费| 国产欧美一区二区精品性| 国产欧美大片| 国产在线麻豆精品观看| 极品少妇一区二区三区精品视频| 韩国精品久久久999| 在线看欧美视频| 日韩天堂在线视频| 亚洲综合日韩| 久久这里有精品15一区二区三区| 欧美成人免费网| 亚洲精品免费观看| 亚洲自拍电影| 久久久久久69| 欧美精品日韩| 国产精品日韩在线| 1024精品一区二区三区| 亚洲免费观看高清完整版在线观看熊| 一区二区三区高清视频在线观看| 亚洲一区二区少妇| 久久久久久自在自线| 亚洲国产精品www| 亚洲午夜伦理| 久久久综合网| 欧美午夜寂寞影院| 亚洲第一色在线| 亚洲欧美成人| 欧美黄色免费| 午夜精品免费视频| 欧美成人精品一区二区三区| 国产精品极品美女粉嫩高清在线| 怡红院精品视频| 午夜影视日本亚洲欧洲精品| 欧美激情一区二区三区高清视频| 一区二区三区四区在线| 久久久久天天天天| 国产精品嫩草99av在线| 最新成人av网站| 久久久无码精品亚洲日韩按摩| 91久久久久久| 久久裸体艺术| 国产欧美日韩在线| 国产精品99久久久久久久久| 欧美激情综合| 欧美在线高清| 国产欧美日韩三级| 亚洲视频1区2区| 亚洲国产经典视频| 久久天堂国产精品| 国产在线观看精品一区二区三区 | 一区二区电影免费观看|