• <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>
            面對(duì)現(xiàn)實(shí),超越自己
            逆水行舟,不進(jìn)則退
            posts - 269,comments - 32,trackbacks - 0
            本文轉(zhuǎn)自:http://blog.csdn.net/bao_qibiao/article/details/4528860

            在MFC程序中,可以用以下幾種方法來(lái)獲取命令行參數(shù)。
            為方便說(shuō)明,我們假設(shè)執(zhí)行了命令:C:/test/app.exe -1 -2

            方法一

            1 ::GetCommandLine ();
            2 //將獲取到 "C:/test/app.exe"  -1 -2 

            方法二

            1 for (int i=0;i<__argc ;i++)
            2 {
            3 __argv [i];
            4 //將依次得到C:/test/app.exe   -1   -2 
            5 }

            方法三

            1 AfxGetApp ()->m_lpCmdLine;
            2 //將獲取到 -1 -2 

             

            posted @ 2012-04-12 12:26 王海光 閱讀(635) | 評(píng)論 (0)編輯 收藏
            本文轉(zhuǎn)自:http://www.flighty.cn/html/bushu/20110322_114.html

            最新的WinVer.nsh下載:
            http://nsis.sourceforge.net/Include/WinVer.nsh(下載后置于\NSIS\Inclued中)

            AtLeastWin<version> 檢測(cè)是否高于指定版本
            IsWin<version> 檢測(cè)指定版本(唯一限定版本)
            AtMostWin<version> 檢測(cè)是否低于指定版本

            <version> 允許的值:
            95、98、ME、NT4、2000、XP、2003、Vista、2008、7、2008R2

            示例1:

            折疊NSIS 代碼
             1 !include "MUI.nsh"  
             2 !include "WinVer.nsh"  
             3 !insertmacro MUI_LANGUAGE "simpchinese"  
             4   
             5 Section     
             6 ${If} ${AtLeastWinVista}   
             7   MessageBox MB_OK "系統(tǒng)為 Vista 或 Vista 以上系統(tǒng)!"  
             8 ${EndIf}   
             9   
            10 ${If} ${IsWin2000}   
            11 ${OrIf} ${IsWinXP}   
            12   MessageBox MB_OK "系統(tǒng)為 2000 或 XP!"  
            13 ${EndIf}   
            14   
            15 ${If} ${AtMostWinXP}   
            16   MessageBox MB_OK "系統(tǒng)版本為 XP 或更低版本的系統(tǒng)!"  
            17 ${EndIf}
            18 SectionEnd    

            示例2:

            折疊NSIS 代碼
             1 !include "MUI.nsh"  
             2 !include "WinVer.nsh"  
             3 !insertmacro MUI_LANGUAGE "simpchinese"  
             4   
             5 Section     
             6 ${Unless} ${ISWinXP}   
             7 MessageBox MB_OK "本程序只能安裝在 Windows XP 系統(tǒng)上!"  
             8 Abort   
             9 ${EndIf}   
            10 SectionEnd 
            posted @ 2012-04-11 17:11 王海光 閱讀(3373) | 評(píng)論 (0)編輯 收藏
                創(chuàng)建一個(gè)新類用來(lái)隱藏主對(duì)話框閃爍問(wèn)題

                注釋下段代碼:
             1   CPrinterMonitorExDlg dlg;
             2   m_pMainWnd = &dlg;
             3   INT_PTR nResponse = dlg.DoModal();
             4   if (nResponse == IDOK)
             5   {
             6    // TODO: Place code here to handle when the dialog is
             7    //  dismissed with OK
             8   }
             9   else if (nResponse == IDCANCEL)
            10   {
            11    // TODO: Place code here to handle when the dialog is
            12    //  dismissed with Cancel
            13   }

                替換成:
            1  CMainDialog dlg;  //新類對(duì)象
            2  m_pMainWnd = &dlg;
            3  dlg.Create(CMainDialog::IDD); 
            4  dlg.ShowWindow(SW_HIDE);      
            5  dlg.RunModalLoop();

                用對(duì)話框隱藏等待程序,在xp系統(tǒng)下會(huì)出現(xiàn)一個(gè)問(wèn)題,就是:如果程序是system權(quán)限啟動(dòng),第一次注銷機(jī)器正常,但第二次注銷時(shí)就會(huì)出現(xiàn)注銷失敗的情況。隱藏的對(duì)話框在注銷時(shí)無(wú)法被關(guān)閉。
                可以用事件等待來(lái)代替上面的程序。
            1 CEvent    m_evtWait;
            2 if (WAIT_FAILED == ::WaitForSingleObject(m_evtWait, INFINITE))
            3     {
            4         DWORD wError = GetLastError();
            5         LOG("WaitForSingleObject函數(shù)出現(xiàn)錯(cuò)誤,錯(cuò)誤代碼:%d,程序退出", wError);
            6         return FALSE;
            7     }
            posted @ 2012-04-10 16:02 王海光 閱讀(604) | 評(píng)論 (0)編輯 收藏
            轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/08/29/60368.html

            問(wèn)題找出整數(shù)1~N范圍和為M的所有集合,M<=N且M>1,集合里的數(shù)不允許重復(fù)。

            解答:這個(gè)問(wèn)題用遞歸解決最簡(jiǎn)單,代碼如下:

             1 #define MAX_NUM 20        //要足夠大
             2 int log[MAX_NUM];        //記錄和數(shù)
             3 int index = 0;            //log[]數(shù)組的當(dāng)前指針
             4 
             5 void calc(int start, int n)
             6 {
             7     if (n == 0)  
             8     {
             9         for(int j = 0; j < index; j++)
            10             printf("%d ", log[j]);
            11         printf("\n");
            12     }
            13     else
            14     {
            15         for(int i = start; i<=n; i++)
            16         {
            17             log[index++= i;    
            18             calc(i + 1, n - i);
            19         }
            20     }
            21 
            22     index--;
            23 }

            如果允許重復(fù)只需要將上面第18條代碼改為:

            calc(i, n - i);

            即可。

            擴(kuò)展問(wèn)題在數(shù)組{5,1,7,9,2,10,11,4,13,14}中找到和為28的所有集合,集合中不允許有重復(fù)的數(shù)。

            解答:第一步要先對(duì)數(shù)組排序,然后按照上去的思路,對(duì)程序略做一些改動(dòng)。
            代碼如下:

             1 #define MAX_NUM 20        //要足夠大
             2 int log[MAX_NUM];        //記錄和數(shù)
             3 int index = 0;            //log[]數(shù)組的當(dāng)前指針
             4 
             5 void calc__(int *nArr     //數(shù)組, 
             6             int start    //數(shù)組起始元素下標(biāo), 
             7             int nArrLen    //數(shù)組長(zhǎng)度, 
             8             int sum)
             9 {
            10     if (sum == 0)  
            11     {
            12         for(int j = 0; j < index; j++)
            13             printf("%d ", log[j]);
            14         printf("\n");
            15     }
            16     else
            17     {
            18         for(int i = start; i < nArrLen; i++)
            19         {
            20             log[index++= nArr[i];    
            21             calc__(nArr, i+1, nArrLen, sum - nArr[i]);
            22         }
            23     }
            24     
            25     index--;
            26 }

            posted @ 2012-04-10 12:37 王海光 閱讀(672) | 評(píng)論 (0)編輯 收藏
            轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/04/17/47357.html


            有一個(gè)單鏈表,其中可能有一個(gè)環(huán),也就是某個(gè)節(jié)點(diǎn)的next指向的是鏈表中在它之前的節(jié)點(diǎn),這樣在鏈表的尾部形成一環(huán)。

            問(wèn)題:

            1、如何判斷一個(gè)鏈表是不是這類鏈表?
            2、如果鏈表為存在環(huán),如何找到環(huán)的入口點(diǎn)?

            解答:

            一、判斷鏈表是否存在環(huán),辦法為:

            設(shè)置兩個(gè)指針(fast, slow),初始值都指向頭,slow每次前進(jìn)一步,fast每次前進(jìn)二步,如果鏈表存在環(huán),則fast必定先進(jìn)入環(huán),而slow后進(jìn)入環(huán),兩個(gè)指針必定相遇。(當(dāng)然,fast先行頭到尾部為NULL,則為無(wú)環(huán)鏈表)程序如下:

            bool IsExitsLoop(slist *head)
            {
                slist
            *slow = head*fast = head;

                while ( fast && fast->next ) 
                {
                    slow 
            = slow->next;
                    fast 
            = fast->next->next;
                   
            if ( slow == fast ) break;
                }

                return !(fast == NULL || fast->next == NULL);
            }

            二、找到環(huán)的入口點(diǎn)

            當(dāng)fast若與slow相遇時(shí),slow肯定沒(méi)有走遍歷完鏈表,而fast已經(jīng)在環(huán)內(nèi)循環(huán)了n圈(1<=n)。假設(shè)slow走了s步,則fast走了2s步(fast步數(shù)還等于s 加上在環(huán)上多轉(zhuǎn)的n圈),設(shè)環(huán)長(zhǎng)為r,則:

            2s = s + nr
            s= nr

            設(shè)整個(gè)鏈表長(zhǎng)L,入口環(huán)與相遇點(diǎn)距離為x,起點(diǎn)到環(huán)入口點(diǎn)的距離為a。
            a + x = nr
            a + x = (n – 1)r +r = (n-1)r + L - a
            a = (n-1)r + (L – a – x)

            (L – a – x)為相遇點(diǎn)到環(huán)入口點(diǎn)的距離,由此可知,從鏈表頭到環(huán)入口點(diǎn)等于(n-1)循環(huán)內(nèi)環(huán)+相遇點(diǎn)到環(huán)入口點(diǎn),于是我們從鏈表頭、與相遇點(diǎn)分別設(shè)一個(gè)指針,每次各走一步,兩個(gè)指針必定相遇,且相遇第一點(diǎn)為環(huán)入口點(diǎn)。程序描述如下:

            slist* FindLoopPort(slist *head)
            {
                slist
            *slow = head, *fast = head;

                while ( fast && fast->next ) 
                {
                    slow 
            = slow->next;
                    fast 
            = fast->next->next;
                   
            if ( slow == fast ) break;
                }

                if (fast == NULL || fast->next == NULL)
               
                return NULL;

                slow 
            = head;
                while (slow != fast)
                {
                     slow 
            = slow->next;
                     fast 
            = fast->next;
                }

                return slow;
            }


            擴(kuò)展問(wèn)題:

            判斷兩個(gè)單鏈表是否相交,如果相交,給出相交的第一個(gè)點(diǎn)(兩個(gè)鏈表都不存在環(huán))。

            比較好的方法有兩個(gè):

            一、將其中一個(gè)鏈表首尾相連,檢測(cè)另外一個(gè)鏈表是否存在環(huán),如果存在,則兩個(gè)鏈表相交,而檢測(cè)出來(lái)的依賴環(huán)入口即為相交的第一個(gè)點(diǎn)。

            二、如果兩個(gè)鏈表相交,那個(gè)兩個(gè)鏈表從相交點(diǎn)到鏈表結(jié)束都是相同的節(jié)點(diǎn),我們可以先遍歷一個(gè)鏈表,直到尾部,再遍歷另外一個(gè)鏈表,如果也可以走到同樣的結(jié)尾點(diǎn),則兩個(gè)鏈表相交。

            這時(shí)我們記下兩個(gè)鏈表length,再遍歷一次,長(zhǎng)鏈表節(jié)點(diǎn)先出發(fā)前進(jìn)(lengthMax-lengthMin)步,之后兩個(gè)鏈表同時(shí)前進(jìn),每次一步,相遇的第一點(diǎn)即為兩個(gè)鏈表相交的第一個(gè)點(diǎn)。

            posted @ 2012-04-09 16:56 王海光 閱讀(752) | 評(píng)論 (0)編輯 收藏
            轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/02/29/43446.html


            void printSList(slist *pList)
            {
                assert(pList);
                
            if (pList == NULL)
                    
            return;

                string str;
                
            while (pList)
                {
                    str 
            = string(*pList) + str;
                    pList 
            = pList->next;
                }

                printf(
            "%s", str.c_str());
            }

            遞歸:

            void printSList(slist *pList)
            {
                assert(pList);
                
            if (pList == NULL)
                    
            return;
                
                
            if (pList->next == NULL)
                    printf(
            "%s"*pList);
                
            else
                {
                    printSList(pList
            ->next);
                    printf(
            "%s"*pList);
                }
            }

            分配一個(gè)數(shù)組,把指針?lè)诺綌?shù)組中,然后for倒著打印
            Status display(LinkList &L)

                  printf("\n---------------------------顯示單鏈線性表----------------------\n"); 
                  LinkList p; 
                  int n[100]; 
                  int j=100; 
                  p=L->next; //打印的時(shí)候應(yīng)該從頭結(jié)點(diǎn)的下一個(gè)結(jié)點(diǎn)開(kāi)始打印,否則會(huì)出現(xiàn)亂碼 
                  printf("\n單鏈表為:\t"); 
                  if(p!=NULL) 
                  { 
                        for(;p!=NULL;--j) 
                        { 
                              n[j-1]=p->date; //j-1是因?yàn)?00要存放頭結(jié)點(diǎn)的位置 
                              p=p->next; 
                        } 
                        for(;j<100;j++) 
                        { 
                              printf("%d",n[j]); 
                        } 
                  } 
                  free(p); 
                  return 1;
            }//display 
            posted @ 2012-04-09 16:41 王海光 閱讀(753) | 評(píng)論 (0)編輯 收藏

            轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/09/12/61708.html

            將字符串里詞順序倒置,如"Times New Roman"變?yōu)?Roman New Times"。以空格為分隔符。

            解決方案為:先將整個(gè)字串倒置,然后依次把倒置后串中的每一個(gè)單詞倒置。

            這個(gè)問(wèn)題解答的思路很簡(jiǎn)單,但是要考慮到很多種的情況,比如字符串的頭、尾有多余的空格怎么辦,如果字符串中只有空格,還有字符串中間可能會(huì)有兩個(gè)以上并列的空格。

            程序如下:

             1 void ReverseStr(char *pStr, int len)
             2 {
             3     assert(pStr);
             4     
             5     char ch;
             6     for (int i = 0; i < len/2 ; i++)
             7     {
             8         ch = pStr[i];
             9         pStr[i] = pStr[len-1-i];
            10         pStr[len-1-i] = ch;
            11     }
            12 }
            13 
            14 void ReverseStrWord(char *pStr, int len)
            15 {
            16     assert(pStr);
            17 
            18     if (len <= 1)
            19         return;
            20 
            21     // 倒置整個(gè)字符串
            22     ReverseStr(pStr, len);
            23 
            24     // 處理頭多余的空格
            25     int i = 0;
            26     if (pStr[0== ' ')            while (pStr[i] == ' ' && i < len)        i++;
            27 
            28     // 整個(gè)串都是空格
            29     if (i == len)
            30         return;
            31 
            32     // 處理尾多余的空格
            33     if (pStr[len - 1== ' ')    while (pStr[len - 1== ' ' && len - 1 > 0)    len--;
            34 
            35     for (int start = i; i < len; i++)
            36     {
            37         // 最后的end要+1
            38         if (i == len-1)
            39         {
            40             ReverseStr(pStr+start, i-start+1);
            41             break;
            42         }
            43 
            44         // 倒置一個(gè)單詞
            45         if (pStr[i] == ' ')
            46         {
            47             ReverseStr(pStr+start, i-start);
            48             start = i+1;
            49             // 處理內(nèi)部并列的空格
            50             if (pStr[start] == ' ')
            51             {
            52                 while(pStr[start] == ' ') {i++;start++;};
            53             }
            54         }
            55     }
            56 }
            57 

             

            posted @ 2012-04-09 13:47 王海光 閱讀(404) | 評(píng)論 (0)編輯 收藏

            [轉(zhuǎn)]寫好代碼的10個(gè)秘密 收藏
            作者:飛哥 (百度)

            先給大家看一段據(jù)說(shuō)是史上最強(qiáng)的程序:
            e100 33 f6 bf 0 20 b5 10 f3 a5 8c c8 5 0 2 50 68 13 1 cb e 1f be a1 1 bf 0 1
            e11b 6 57 b8 11 1 bb 21 13 89 7 4b 4b 48 79 f9 ad 86 e0 8b c8 bd ff ff e8 20
            e134 0 3d 0 1 74 1a 7f 3 aa eb f3 2d ff 0 50 e8 f 0 5a f7 d8 8b d8 26 8a 1 aa
            e14f 4a 75 f9 eb de cb 57 bb 21 13 8b c1 40 f7 27 f7 f5 8b fb ba 11 1 4f 4f 4a
            e168 39 5 7f f9 52 8b c5 f7 25 f7 37 2b c8 95 f7 65 2 f7 37 95 2b e8 fe e fe
            e181 10 79 6 c6 6 fe 10 7 46 d0 14 d1 d1 d1 e5 79 ec 5a b8 11 1 ff 7 4b 4b 48
            e19b 3b d0 75 f7 5f c3 83 f7 83 a6 5d 59 82 cd b2 8 42 46 9 57 a9 c5 ca aa 1b
            .............................................................................


            這段程序是1997年世界程序設(shè)計(jì)大賽的一等獎(jiǎng)作品的部分代碼(完整的代碼下載,把代碼復(fù)制粘貼到cmd的debug命令中,回車看到效果)。這個(gè)程序運(yùn)行后將是一個(gè)3D的且伴隨著音樂(lè)的動(dòng)畫(huà)。震撼吧!
            是不是從事軟件開(kāi)發(fā)的人員都希望成為這樣的武林高手呢?然而真要是用這樣的高手來(lái)設(shè)計(jì)、編寫我們的產(chǎn)品代碼,恐怕某一天,我們什么都不用干了,只能人手一本機(jī)器代碼,一句一句進(jìn)行翻譯了;那么對(duì)于軟件產(chǎn)品開(kāi)發(fā)而言,如何寫好代碼呢?一流的軟件產(chǎn)品的代碼具備哪些特征呢?


             

            一流代碼的特征


            1、穩(wěn)定可靠(Robustness)
            代碼寫出來(lái)以后,一定要能夠運(yùn)行得非常好,非常穩(wěn)定可靠。在現(xiàn)今的IT行業(yè),軟件產(chǎn)品都是是24*7,即要保證系統(tǒng)一天24小時(shí),一星期7天中都可以無(wú)間斷的正常運(yùn)行。比如我們百度的搜索引擎系統(tǒng),比如我們的通信系統(tǒng),等等。到了產(chǎn)品開(kāi)發(fā)后期,大部分的成本都將投入到產(chǎn)品穩(wěn)定性的提高。

            2、可維護(hù)且簡(jiǎn)潔(Maintainable and Simple Code)
            在寫代碼時(shí),首先要考慮的是:寫出來(lái)的代碼不但要自己可以讀懂,而且我們的同事、測(cè)試工程師都可能要修改這些代碼,對(duì)其進(jìn)行增減。如果代碼很復(fù)雜,不容易讀懂,如程序中的遞歸一大堆、程序不知何時(shí)或從何地跳出,則會(huì)使程序的可維護(hù)性和簡(jiǎn)潔性降低。所以必要的注釋、統(tǒng)一的編程規(guī)范等都是非常重要的。

            3、高效(Fast)
            在軟件行業(yè)中效率是非常重要的,比如搜索引擎。有些軟件的搜索效率就不高,搜索過(guò)程特別緩慢,讓人難以接受。當(dāng)然這里面有一個(gè)帶寬的問(wèn)題,但是程序效率不高也是一個(gè)重要的原因。而實(shí)際上程序的效率提高,有時(shí)候很簡(jiǎn)單,并沒(méi)有什么神秘之處,如使用數(shù)組索引時(shí)候,可以用指針?lè)绞蕉皇褂脭?shù)組下標(biāo);數(shù)組的空間定義應(yīng)該定義為2的N次冪等等。

            4、簡(jiǎn)短(Small)
            這方面大家的感受可能不是很深,但是我的感受是很深的。配置過(guò)PSTN程控交換機(jī)、路由器、VoIP網(wǎng)關(guān)設(shè)備的人都知道,這些設(shè)備的軟件都是從PC機(jī)通過(guò)網(wǎng)口或串口下載到這些設(shè)備的Flash上(類似PC機(jī)的BIOS)再通過(guò)設(shè)備上的CPU啟動(dòng)。如果程序?qū)懙暮芰_嗦,隨著特性不斷增加,程序規(guī)模將變大的巨大,F(xiàn)lash空間告急、內(nèi)存告急、下載升級(jí)變的不可忍受,等等,帶來(lái)的就是成本不斷增加,利潤(rùn)不斷下降。

            5、共享性(Reusable)
            如果做大型產(chǎn)品開(kāi)發(fā),程序的共享性也是非常重要的。我們產(chǎn)品有那么多開(kāi)發(fā)人員,如果每一個(gè)人都自己定義字符串、鏈表等數(shù)據(jù)結(jié)構(gòu),那么開(kāi)發(fā)效率就會(huì)降低,我們的產(chǎn)品恐怕到今天也不能出臺(tái)。我所說(shuō)的“共享”不是指將別人的代碼復(fù)制到自己的代碼中,而是指直接調(diào)用別人的代碼,拿來(lái)即可用。這一方面可以減少代碼的冗余性,另一方面可以增強(qiáng)代碼的可維護(hù)性。如果別人的代碼里有Bug,只需修改他的代碼,而調(diào)用此代碼的程序不用進(jìn)行任何修改就可以達(dá)到同步。這同時(shí)要求我們?cè)谠O(shè)計(jì)的時(shí)候,如何考慮系統(tǒng)的內(nèi)聚和耦合的問(wèn)題。

            6、可測(cè)試性(Testable)
            我們的產(chǎn)品開(kāi)發(fā)里,除了軟件開(kāi)發(fā)人員,還有一部分工程師負(fù)責(zé)軟件測(cè)試。軟件測(cè)試人員會(huì)將開(kāi)發(fā)代碼拿來(lái),一行一行地運(yùn)行,看程序運(yùn)行是否有錯(cuò)。如果軟件開(kāi)發(fā)人員的代碼不可測(cè)試,那測(cè)試工程師就沒(méi)有辦法進(jìn)行工作。因此可測(cè)試性在大型軟件開(kāi)發(fā)里是很重要的一點(diǎn)。可測(cè)試性有時(shí)候與可維護(hù)性是遙相呼應(yīng)的,一個(gè)具有好的可測(cè)試性和可維護(hù)性的代碼,測(cè)試人員可以根據(jù)開(kāi)發(fā)提供的維護(hù)手冊(cè)、debug信息手冊(cè)等就可以判斷出程序出錯(cuò)在哪個(gè)模塊。

            7、可移植性(Portable)
            可移植性是指程序?qū)懗鰜?lái)以后,不僅在windows 2000里可以運(yùn)行,在NT/9X下可以運(yùn)行,而且在Linux甚至Macintosh等系統(tǒng)下都可以運(yùn)行。所有這些特性都是一流代碼所具備的特性。但是其中有些特性是會(huì)有沖突的。比如高效性,程序?qū)懙男屎芨撸涂赡茏兊煤軓?fù)雜,犧牲的就是簡(jiǎn)潔。好的代碼要在這些特性中取得平衡。

             

            寫好代碼的10個(gè)秘密

            1、百家之長(zhǎng)歸我所有(Follow Basic Coding Style)
            其實(shí)寫代碼的方式有很多,每個(gè)人都有自己的風(fēng)格,但是眾多的風(fēng)格中總有一些共性的、基本的寫代碼的風(fēng)格,如為程序?qū)懽⑨尅⒋a對(duì)齊,等等。是不是編程規(guī)范?對(duì)就是編程規(guī)范。

            2、取個(gè)好名字(Use Naming Conventions)
            取個(gè)好的函數(shù)名、變量名,最好按照一定的規(guī)則起名。還是編程規(guī)范。

            3、凌波微步,未必摔跤(Evil goto's?Maybe Not...)
            這里我用“凌波微步”來(lái)形容goto語(yǔ)句。通常,goto語(yǔ)句使程序跳來(lái)跳去,不容易讀,而且不能優(yōu)化,但是在某種情況下,goto語(yǔ)句反而可以增強(qiáng)程序的可讀性。Just go ahead,not go back。

            4、先發(fā)制人,后發(fā)制于人(Practic Defensive Coding)
            Defensive Coding指一些可能會(huì)出錯(cuò)的情況,如變量的初始化等,要考慮到出現(xiàn)錯(cuò)誤情況下的處理策略。測(cè)試時(shí)要多運(yùn)行幾個(gè)線程。有些程序在一個(gè)線城下運(yùn)行是正常的,但是在多個(gè)線程并行運(yùn)行時(shí)就會(huì)出現(xiàn)問(wèn)題;而有些程序在一個(gè)CPU下運(yùn)行幾個(gè)線程是正常的,但是在多個(gè)CPU下運(yùn)行時(shí)就會(huì)出現(xiàn)問(wèn)題,因?yàn)閱蜟PU運(yùn)行線程只是狹義的并行,多CPU一起運(yùn)行程序,才是真正的并行運(yùn)算。

            5、見(jiàn)招拆招,滴水不漏(Handle The Error Cases:They Will Occur!)
            這里的Error Case(錯(cuò)誤情況),是指那些不易重視的錯(cuò)誤。如果不對(duì)Error Case進(jìn)行處理,程序在多數(shù)情況下不會(huì)出錯(cuò),但是一旦出現(xiàn)異常,程序就會(huì)崩潰。 6、熟習(xí)劍法刀術(shù),所向無(wú)敵(Learn Win32 API Seriously)
            用“劍法刀術(shù)”來(lái)形容一些API是因?yàn)樗鼈兌际墙?jīng)過(guò)了很多優(yōu)秀開(kāi)發(fā)人員的不斷開(kāi)發(fā)、測(cè)試,其效率很高,而且簡(jiǎn)潔易懂,希望大家能掌握它,熟悉它,使用它。是不是象我們的ULIB。

            7、雙手互搏,無(wú)堅(jiān)不摧(Test,but don't stop there)
            這里的測(cè)試不是指別人來(lái)測(cè)試你的代碼,而是指自己去測(cè)試。因?yàn)槟闶菍懘a的原作者,對(duì)代碼的了解最深,別人不可能比你更了解,所以你自己在測(cè)試時(shí),可以很好地去測(cè)試哪些邊界條件,以及一些意向不到的情況。

            8、活用斷言(Use,don't abuse,assertions)
            斷言(assertion)是個(gè)很好的調(diào)試工具和方法,希望大家能多用斷言,但是并不是所有的情況下都可以用到斷言。有些情況使用斷言反而不合適。

            9、草木皆兵,不可大意(Avoid Assumptions)
            是指在寫代碼時(shí),要小心一些輸入的情況,比如輸入文件、TCP的sockets、函數(shù)的參數(shù)等等,不要認(rèn)為使用我們的API的用戶都知道什么是正確的、什么是錯(cuò)的,也就是說(shuō)一定要考慮到對(duì)外接口的出錯(cuò)處理問(wèn)題。

            10、最高境界、無(wú)招勝有招(Stop writing so much code)
            意思就是說(shuō)盡量避免寫太多的代碼,寫的越多,出錯(cuò)的機(jī)會(huì)也越多。最好能重用別人開(kāi)放的接口函數(shù)或直接調(diào)用別人的api。

             

            本文來(lái)自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://www.shnenglu.com/humanchao/archive/2010/08/05/122334.html

            posted @ 2012-04-09 13:36 王海光 閱讀(496) | 評(píng)論 (0)編輯 收藏
            使用插件:http://nsis.sourceforge.net/NsRandom_plug-in

            轉(zhuǎn)自:http://www.dreams8.com/thread-11726-1-1.html
             1 Function Random
             2 Exch $0
             3 Push $1
             4 System::Call 'kernel32::QueryPerformanceCounter(*l.r1)'
             5 System::Int64Op $1 % $0
             6 Pop $0
             7 Pop $1
             8 Exch $0
             9 FunctionEnd
            10 
            11 Push "100" 
            12 Call Random
            13 Pop $0


            posted @ 2012-04-06 17:13 王海光 閱讀(1307) | 評(píng)論 (0)編輯 收藏
             轉(zhuǎn)自:http://www.shnenglu.com/huangyi5209/articles/143171.html
             1 !include MUI.nsh
             2        
             3 Function GetDiskVolumeSerialNumber
             4 !define GetVolumeInformation "Kernel32::GetVolumeInformation(t,t,i,*i,*i,*i,t,i) i"
             5 System::Call '${GetVolumeInformation}("$0",,${NSIS_MAX_STRLEN},.r0,,,,${NSIS_MAX_STRLEN})'
             6 FunctionEnd
             7 
             8 Section
             9 StrCpy $0 "C:\"
            10 Call GetDiskVolumeSerialNumber
            11 IntFmt $0 "%08X" $0
            12 MessageBox MB_OK "$0"
            13 SectionEnd


            posted @ 2012-04-06 17:10 王海光 閱讀(810) | 評(píng)論 (0)編輯 收藏
            僅列出標(biāo)題
            共27頁(yè): First 19 20 21 22 23 24 25 26 27 
            亚洲精品无码久久久久sm| 狠狠色丁香婷婷久久综合不卡| 婷婷伊人久久大香线蕉AV | 青青草原1769久久免费播放| 人人狠狠综合88综合久久| 久久精品麻豆日日躁夜夜躁| 亚洲色欲久久久久综合网| 久久99精品国产麻豆宅宅| 伊人色综合久久天天人手人婷| 国产亚洲成人久久| 99久久精品日本一区二区免费| 超级碰碰碰碰97久久久久| 精品无码人妻久久久久久| 国产精品久久久久久吹潮| 久久精品国产亚洲AV不卡| 久久久久国产精品三级网| 国产精品欧美久久久久无广告| 国产成人无码久久久精品一| 综合久久国产九一剧情麻豆 | 精品国产乱码久久久久软件 | 国产福利电影一区二区三区久久久久成人精品综合 | 色诱久久久久综合网ywww| 午夜视频久久久久一区| 久久国产三级无码一区二区| 91精品国产91热久久久久福利| 精品永久久福利一区二区| 久久精品蜜芽亚洲国产AV| 久久久噜噜噜www成人网| 久久一区二区三区免费| 97久久精品人妻人人搡人人玩| 亚洲国产精品无码成人片久久| 久久狠狠爱亚洲综合影院| 亚洲国产成人精品91久久久| 天天影视色香欲综合久久| 色欲综合久久躁天天躁| 久久综合成人网| 一97日本道伊人久久综合影院| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 人妻少妇久久中文字幕| 人妻无码αv中文字幕久久 | 97久久婷婷五月综合色d啪蜜芽|