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

隨筆-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国产精品久久| 亚洲主播在线| 久久另类ts人妖一区二区| 久久女同互慰一区二区三区| 蜜桃av噜噜一区| 欧美黄色aa电影| 欧美激情aⅴ一区二区三区| 欧美日韩亚洲在线| 国产香蕉97碰碰久久人人| 国产一区自拍视频| 亚洲日韩欧美视频| 亚洲欧美影院| 亚洲电影在线| 亚洲一卡久久| 久久深夜福利免费观看| 欧美理论电影网| 国产日产欧产精品推荐色| 亚洲黄色在线| 久久久久久久久岛国免费| 91久久久久久久久久久久久| 亚洲视频1区2区| 欧美18av| 国内外成人免费视频| 亚洲精品一区二区在线| 午夜影视日本亚洲欧洲精品| 亚洲国产精品视频| 欧美有码在线观看视频| 欧美高清在线观看| 韩日午夜在线资源一区二区| 夜久久久久久| 欧美va天堂在线| 小嫩嫩精品导航| 欧美高清在线视频观看不卡| 红桃视频欧美| 日韩午夜激情av| 久久综合网hezyo| 在线视频免费在线观看一区二区| 久久精品亚洲精品国产欧美kt∨| 欧美三级乱码| 最新日韩精品| 女仆av观看一区| 久久疯狂做爰流白浆xx| 国产精品人人做人人爽人人添| 亚洲精选视频免费看| 久久久久久婷| 亚洲欧美中文另类| 国产精品日韩精品欧美精品| 日韩一区二区精品| 亚洲国产毛片完整版 | 国产美女诱惑一区二区| 日韩午夜在线电影| 欧美大片免费观看| 毛片精品免费在线观看| 精品999网站| 欧美一区二区三区免费看| 99国产精品99久久久久久| 久久精品一本| 在线成人黄色| 欧美激情91| 久热精品视频| 亚洲国产精品va在看黑人| 蜜臀99久久精品久久久久久软件| 亚洲欧美日韩精品久久久| 国产精品五月天| 一区二区三区.www| 亚洲精品国精品久久99热| 免费日韩av| 在线视频亚洲一区| 在线视频精品一| 国产精品综合色区在线观看| 亚洲免费一在线| 欧美一乱一性一交一视频| 国产欧美日本一区二区三区| 欧美亚洲日本网站| 久久精品国产在热久久| 在线成人激情视频| 亚洲黄色免费网站| 国产精品福利影院| 欧美一区二区三区免费在线看| 久久不射网站| 91久久国产精品91久久性色| 亚洲国产日本| 国产日韩欧美日韩| 欧美国产91| 国产精品第一区| 久久激情综合网| 老司机成人网| 亚洲一区在线直播| 欧美另类一区| 国产精品成人一区二区艾草| 亚洲天堂成人在线视频| 亚洲一区久久久| 在线观看视频一区二区| 亚洲精品系列| 国内偷自视频区视频综合| 亚洲精品乱码久久久久| 国产午夜亚洲精品不卡| 亚洲激情校园春色| 国产亚洲精品高潮| 亚洲精品美女在线观看| 国产视频一区二区三区在线观看| 你懂的国产精品| 国产精品v欧美精品v日韩| 久久婷婷麻豆| 国产精品高潮呻吟久久| 欧美承认网站| 国产亚洲欧美激情| aa级大片欧美三级| 亚洲毛片播放| 久久久999成人| 亚洲免费在线视频一区 二区| 久久国产免费| 一区二区三区精品久久久| 久久精品一区二区| 久久精品在线视频| 国产精品午夜av在线| 狠色狠色综合久久| 亚洲一区二区三区在线观看视频 | 一区二区三区精品在线| 在线高清一区| 性刺激综合网| 午夜久久资源| 国产精品久久久久久久久免费| 欧美高清在线观看| 亚洲成色777777在线观看影院| 亚洲在线观看| 亚洲少妇在线| 欧美日韩免费区域视频在线观看| 欧美激情精品久久久久久免费印度 | 国精产品99永久一区一区| 一区二区三区精品视频| 亚洲人体1000| 麻豆成人精品| 欧美成人精品1314www| 欧美色图一区二区三区| 99国产精品久久久久久久久久| 一区二区三区产品免费精品久久75| 久久福利毛片| 欧美二区在线看| 在线免费不卡视频| 欧美大片在线观看| 嫩草成人www欧美| 99在线精品视频在线观看| 欧美日韩国产首页| 在线视频欧美日韩精品| 欧美在线1区| 久久亚洲精品伦理| 亚洲国产合集| 欧美一区二区三区视频| 久久一本综合频道| 最新国产拍偷乱拍精品| 亚洲视频一区二区| 国产精品福利在线观看| 亚洲欧美在线aaa| 欧美成人激情视频| 亚洲乱码精品一二三四区日韩在线| 欧美欧美午夜aⅴ在线观看| 99精品99| 鲁大师影院一区二区三区| 亚洲全黄一级网站| 欧美日韩一区二区在线观看| 亚洲午夜女主播在线直播| 久久综合综合久久综合| 亚洲精品久久久久中文字幕欢迎你 | 亚洲黄色小视频| 亚洲视频精品在线| 国产精品久久久久久久久| 欧美在线视频一区| 亚洲国产一区二区三区高清| 亚洲神马久久| 国产日韩欧美在线播放| 久久精品国产欧美亚洲人人爽| 亚洲高清资源| 性欧美精品高清| 在线高清一区| 欧美人成免费网站| 欧美一区二区三区视频免费| 久久久久久电影| 亚洲色图制服丝袜| …久久精品99久久香蕉国产| 欧美体内she精视频| 久久成人人人人精品欧| 亚洲国产mv| 久久视频一区| 亚洲在线1234| 亚洲精品乱码久久久久| 国产日韩欧美视频在线| 欧美日韩日韩| 欧美成人蜜桃| 久久在线免费| 欧美一区二区三区四区在线|