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

隨筆-90  評論-947  文章-0  trackbacks-0
 

昨天晚上和同事討論寫 Log 的問題,談到寫到文件,后來談到寫文件用 ReadFile、WriteFile 還是用 fread、fwrite 的問題。我一直對 fread、fwrite 沒啥好感,原因是它自作主張的搞了一套緩存機制??墒莾H僅這點就鄙視它似乎還說不過去。談著談著,后來我們對它的參數設計起了懷疑——這里有一個參數是多余的!從表面看,ReadFile、WriteFile 的參數是恰到好處的,fread、fwrite 作為它們的上層函數,似乎沒必要把一個參數拆成 2 個呀。

后來就一直跟 fread,直到出現 ReadFile,都沒發現這 2 個參數有什么特別的用處,他們很早就被乘起來了:

count = total = elementSize * count;

所以,目前我仍然對這個設計感到困惑。

有誰知道,這是由于什么樣的歷史原因/技術原因,才使這個函數變成現在這副模樣的?

posted @ 2010-04-04 19:41 溪流 閱讀(5372) | 評論 (35)編輯 收藏

我原先不喜歡加 Log,后來我的頭兒希望加 Log,于是乎我手頭的項目就全是 Log 了。之前一直是定義一個不定參數的宏或者函數,遇到需要的地方就 LOG(...)。后來越來越感覺對于函數進出的信息比較渴求,于是弄了個固定的 LOG_FUNCTION() 來記錄函數進入,因為有 __FUNCTION__ 嘛。

對于函數出口,原先一直是手寫的,剛剛前幾天在這里討論的資源釋放問題讓我學到了新的解決方法——使用類似 Loki::ScopeGuard 的機制來輸出函數退出。

晚上重新寫了一下。見 http://code.google.com/p/xllog/

使用如下:

void bar()
{
   
XL_LOG_FUNCTION();
   
XL_LOG(L"%s\n", L"In function bar.");
}

void foo()
{
   
XL_LOG_FUNCTION();
   
XL_LOG(L"%s\n", L"In function foo.");

   
bar();
}

int main()
{
   
XL_LOG_FUNCTION();

   
foo();

   
return 0;
}

運行結果:

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Enter Function main
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Enter Function foo
In function foo.
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> Enter Function bar
In function bar.
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< Leave Function bar
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< Leave Function foo
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< Leave Function main

基本功能我自己已經可以接受了。

有兩點我想改進的,不知道能不能實現:

1、每個用到的函數寫一句 XL_LOG_FUNCTION() 太麻煩了,而且有可能被用戶寫到任意地方,而非函數開始。有沒有一種機制,使得可以寫成類似(要保持函數定義的形式,不要把函數名括號括起來):

void __log foo()
{
}

從而被展開成:

void foo()
{
    XL_LOG_FUNCTION();
}

呢?

或者有沒有一種方法可以不用寫任何東西就讓每個函數體自動加上這么一句呢?

2、我想記錄函數的調用層次。如果上面行能夠實現的話,就沒問題了,我可以自己記錄函數進出次數。如果不能,那么依靠用戶寫 XL_LOG_FUNCTION() 來記錄就不可靠了。有沒有類似 __CALL_STACK_DEPTH__ 的預定義宏呢?

最后還有一個實際問題。實際使用中,在寫代碼的時候可能無法確定所寫部位到底是偏底層還是偏上層。如果太偏底層而打了 Log,會輸出很多 Log 干擾分析;如果太高層的而沒打 Log,有可能遇到問題信息不足。這個問題該如何解決好呢?大家有沒有成熟的解決思路呢?

posted @ 2010-04-04 01:31 溪流 閱讀(2403) | 評論 (14)編輯 收藏

最近有個東西,需要讀 XML 配置文件,于是用 msxml 做了。msxml 是基于 COM 的,使用之前需要 CoInitialize,使用之后需要 CoUninitialize。于是我寫成了:

void foo()
{
    CoInitialize(NULL);

    // Reading configuration

    CoUninitialize();
}

剛才我正樂此不彼的把類似這樣的東西改成:

void foo()
{
    CoInitialize(NULL);
    LOKI_ON_BLOCK_EXIT(CoUninitialize);

    // Reading configuration
}

前面的同事過來看到了,說,你不該在這里調用 CoInitialize 和 CoUninitialize。如果有的地方也在用 COM,你這里 CoUninitialize 一下,別的地方就會出錯了,上次的某個 Bug 就是。

我狡辯道:我假定這里沒有多線程環境(實際上也是),并且約定別的地方用 COM 的時候調用 CoInitialize 時不要判斷返回值。

同事:應該和大眾習慣保持一致,最好就是全項目最開始的時候 CoInitialize 一次,結束的時候 CoUninitialize 一次。

我:我這里是較底層功能函數。

同事:可以以文檔的方式注明,使用該模塊前必須自己 CoInitialize,使用完畢后自己 CoUninitialize。

我:我只是想要用起來方便一點,用的時候不要有那么多先決條件和后置條件。再說,人家本來可以不知道我用了 COM,我這么一說明,就暴露了內部信息了不是?

其實我被動搖了。

各位大大,你們怎么處理呢?

------------------------------華麗的分割線(13:27 p.m. 增加)----------------------------------

好,既然 CoInitialize 和 CoUninitialize 有引用計數機制,那么這個具體問題已經解決。

那么,有沒有類似的成對使用的 API,會對進程全局產生影響的呢?如果有,在底層要用到的時候該怎么處理?

posted @ 2010-04-02 10:02 溪流 閱讀(25196) | 評論 (17)編輯 收藏

如題。

沒有界面、不帶任何文檔的軟件怎么辦?

posted @ 2010-03-31 17:23 溪流 閱讀(5885) | 評論 (10)編輯 收藏

先看一個例子。首先,我要寫一個vector;其次,為了使用方便,我需要提供一個帶 size 參數的構造函數。要求就這兩點。

那么,勢必要:

class vector
{
public:
    vector(size_t size)
    {
        // ...
        m_pData = new int[size]; // 假設就是 int 這樣的基本類型好了,以避免下面可能出現的離題
        // ...
    }
};

問題來了。new 不是有可能失敗嗎?失敗了在老編譯器里會返回 NULL(這個情形也先無視),在新編譯器里會拋異常。那么,在這里要不要進行檢查呢?如果檢查:

try
{
    m_pData = new int[size];
}
catch (...)
{

}

catch到了。那么在這里可以干啥呢?似乎。。。啥也干不了!作為構造函數,沒法使用返回值,自然只能使用異常來提示外界;既然本來就是異常,我又何必在這里 try 一次呢?(假設這里沒有其他錯誤要處理,也假設這里的類型是int之類的基本類型,不會出現執行元素的構造函數失敗的情形)

既然這里的 try 讓我們如此無奈,那么就不必 try 了。這個時候,我需要給 vector(size_t size) 標記上 throw 嗎?如果不標記,使用者怎么知道這里可能會有異常?如果標記了,或者沒標記但使用者意識到了,那么他會這樣用:

try
{
    vector v(10);
    // Task with v
    // ...
    // ...
    // ...
}
catch (...)
{
    // Error handler
}

因為 v 的作用域被限制在了 try 內,所以所有的與 v 相關的邏輯代碼全部要放在 try 內部了。這種樣子似乎與 C# 很像!在 C# 里,try...catch... 是標準的做法;但是在 C++ 里,似乎不會如此經常地用 try catch,要不然,為什么我見過的 C++ 代碼都不是這樣子的呢?兩年前在金山實習的時候,有一次我把 try...catch 當做通用的錯誤處理來做,所有的錯誤都搞成一種異常,返回值僅返回正常值。結果董波叔叔說,這樣子是不對滴,但是沒給出讓我信服理由,可能就是,C++ 的 try...catch 的性能很不好之類的。(C# 以及 Java 的 try...catch 的性能好嗎?)

好,既然大家都不這么辦,是不是這里也不用 try 了?于是,內存分配錯誤就讓它自生自滅了……記得以前某本書上看到,說這種情形下的處理,僅僅是一個道德問題而已。真的無解嗎?

如果放寬要求,不要求在構造函數提供內存分配,那倒是有一種解法——分兩階段構造:

class vector
{
public:
    vector()
    {
        // ...
    }
    bool allocate(size_t size)
    {
        try
        {
            m_pData = new int[size];
        }
        catch (...)
        {
            return false;
        }
        if (m_pData == NULL)
        {
            return false;
        }
        // Other code ...
        return true;
    }
};

但是使用起來就不“方便”了?,F實中,這種情形倒是存在,如 CWindow 的 Create,還有啥啥啥的 Init 等等。

真的沒有辦法兼顧方便與安全嗎?

posted @ 2010-03-30 22:31 溪流 閱讀(2424) | 評論 (15)編輯 收藏
僅列出標題
共18頁: First 10 11 12 13 14 15 16 17 18 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            99精品国产高清一区二区| 中文亚洲视频在线| 欧美激情精品久久久久久久变态| 久久爱www| 欧美在线关看| 久久夜色精品国产亚洲aⅴ| 久久艳片www.17c.com| 欧美电影免费| 国产精品久久久久久久久久ktv| 国产精品日韩| 在线免费高清一区二区三区| 亚洲精品在线电影| 亚洲欧美日本视频在线观看| 久久黄色影院| 亚洲国产精品www| 亚洲精品久久嫩草网站秘色 | 红桃视频欧美| 亚洲国产欧美在线人成| 宅男精品视频| 老鸭窝亚洲一区二区三区| 亚洲国产婷婷综合在线精品| 亚洲欧美变态国产另类| 欧美成人黑人xx视频免费观看| 国产精品美女xx| 亚洲人久久久| 久久九九免费视频| 亚洲免费观看高清完整版在线观看熊| 午夜精品婷婷| 欧美日韩国产经典色站一区二区三区| 国产美女搞久久| 一本色道久久综合亚洲精品不| 久久久噜噜噜久久中文字幕色伊伊| 亚洲区欧美区| 久久亚洲欧美| 国产乱子伦一区二区三区国色天香 | 日韩一级片网址| 欧美一区二区精品| 欧美激情视频在线播放 | 亚洲欧美在线另类| 亚洲国产精品悠悠久久琪琪| 欧美一区二区观看视频| 国产精品久久久久影院亚瑟| 亚洲理论电影网| 欧美99在线视频观看| 亚久久调教视频| 国产麻豆午夜三级精品| 午夜精品久久久久久99热| 日韩一区二区精品在线观看| 欧美大片一区二区| 亚洲日本va午夜在线影院| 免费视频一区| 久久精彩免费视频| 国产一区二区成人| 久久久久国产一区二区三区四区| 亚洲深夜福利视频| 国产精品美女久久久久久免费| 亚洲视频在线一区观看| 一区二区福利| 国产精品久久久久国产精品日日| 一本色道久久综合亚洲精品不卡| 亚洲国产综合在线看不卡| 欧美成人国产va精品日本一级| 最新高清无码专区| 亚洲欧洲视频在线| 欧美日韩亚洲三区| 欧美一级日韩一级| 久久大香伊蕉在人线观看热2| 韩日午夜在线资源一区二区| 久久影院午夜论| 蜜桃伊人久久| 99精品热6080yy久久| 妖精成人www高清在线观看| 国产精品久久久久久五月尺 | 亚洲精品久久久久久一区二区| 欧美剧在线免费观看网站| 中文国产亚洲喷潮| 午夜精品久久久久久久久 | 亚洲电影免费观看高清| 免费在线欧美视频| 欧美精品日韩| 欧美一区三区二区在线观看| 久久激情视频久久| 夜夜爽99久久国产综合精品女不卡 | 99视频精品全国免费| 欧美日韩综合另类| 久久精品视频亚洲| 嫩草影视亚洲| 欧美精品三级| 日韩亚洲国产欧美| 亚洲成人直播| 亚洲国产片色| 欧美日韩国产综合视频在线观看| 亚洲一二三级电影| 欧美一区二区性| 亚洲裸体俱乐部裸体舞表演av| 在线综合视频| 亚洲高清久久久| 亚洲一级在线观看| 亚洲黄色av一区| 香蕉久久一区二区不卡无毒影院| 亚洲精品国产精品国自产观看浪潮| 这里只有精品电影| 91久久精品国产91久久性色| 亚洲一区国产| 亚洲日韩欧美一区二区在线| 亚洲欧美成人网| 99精品国产在热久久婷婷| 久久精品国产精品亚洲| 亚洲专区在线视频| 欧美激情片在线观看| 久久女同互慰一区二区三区| 国产精品qvod| 亚洲精品一二三区| 91久久精品www人人做人人爽| 欧美一级黄色网| 亚洲欧美日韩精品在线| 欧美精品一区二区蜜臀亚洲| 久久综合色天天久久综合图片| 国产精品久久久久久妇女6080 | 欧美色中文字幕| 欧美国产视频在线观看| 国产视频欧美视频| 亚洲图片你懂的| 在线一区二区三区做爰视频网站| 久久精品亚洲一区| 久久精品91久久久久久再现| 欧美色另类天堂2015| 亚洲国产免费| 亚洲免费观看高清完整版在线观看熊 | 久久成人精品视频| 欧美在线啊v| 国产精品一区在线播放| 亚洲天堂av在线免费| 亚洲免费影视第一页| 国产精品国产三级国产aⅴ入口 | 午夜精品影院| 久久久99免费视频| 国际精品欧美精品 | 国产精品久久影院| 一区二区三区免费在线观看| 亚洲少妇自拍| 国产精品久久久久久户外露出| 99精品视频免费观看| 亚洲欧美综合v| 亚洲一级一区| 欧美一区二区成人6969| 国产亚洲欧美日韩美女| 久久久久国产精品一区| 麻豆91精品91久久久的内涵| 亚洲成色精品| 欧美日本精品一区二区三区| 日韩亚洲欧美综合| 欧美一区二区视频97| 国内精品久久久久伊人av| 久久五月天婷婷| 亚洲七七久久综合桃花剧情介绍| 亚洲无线一线二线三线区别av| 国产精品日韩电影| 久久久久久69| 日韩视频在线观看一区二区| 欧美一级日韩一级| 亚洲国产精品成人综合色在线婷婷| 欧美精品91| 午夜视频一区| 欧美激情精品久久久久久免费印度| 亚洲精品美女久久久久| 国产精品乱人伦一区二区| 久久精品成人一区二区三区| 最新成人在线| 久久久精品一区二区三区| 亚洲精品午夜| 国产一区二区黄| 欧美日韩精品久久久| 久久国产精品久久久久久电车| 亚洲人成免费| 看片网站欧美日韩| 午夜精品久久久99热福利| 亚洲激情女人| 国产亚洲精品v| 欧美日韩情趣电影| 老司机精品导航| 午夜亚洲福利| 日韩一级精品视频在线观看| 美女视频网站黄色亚洲| 性欧美办公室18xxxxhd| 99精品免费| 亚洲欧洲精品成人久久奇米网| 国产日本欧美一区二区三区| 欧美日本不卡| 欧美成人精品福利| 久久久久久久久一区二区| 亚洲一区尤物| 9l视频自拍蝌蚪9l视频成人| 美女主播视频一区| 久久久久一区二区三区四区| 午夜在线播放视频欧美| 亚洲一区二区三区影院| aa日韩免费精品视频一| 亚洲日本va午夜在线电影 | 亚洲国产mv|