本文轉(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
本文轉(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:
折疊展開(kāi)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:
折疊展開(kāi)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
創(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 }
轉(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 }
轉(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)。
轉(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
轉(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
[轉(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
轉(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