• <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>
            隨筆 - 31  文章 - 128  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(5)

            隨筆分類(38)

            隨筆檔案(31)

            收藏夾(4)

            College

            High School

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 55887
            • 排名 - 407

            最新評論

            • 1.?re: [yc]詳解link
            • 面試的時候面試官就問過我什么是編譯和鏈接,我說編譯就是把代碼文件生成目標文件,鏈接就是把目標文件生成可執行文件,他說不對,又問我什么是動態鏈接,還問我預編譯都做什么處理。。。都在這里找到了答案!!!!
            • --王至乾
            • 2.?re: [yc]詳解link
            • @劉偉
              我是說博主,不是叫你啊
            • --溪流
            • 3.?re: [yc]詳解link
            • 誰是石老師,我不是哈@溪流
            • --劉偉
            • 4.?re: [yc]詳解link
            • 石老師?我是溪流~
            • --溪流
            • 5.?re: [yc]詳解link
            • 期待樓主下文啊,多謝樓主了
            • --劉偉

            閱讀排行榜

            評論排行榜

            此處廢棄,新家http://hi.baidu.com/shifan3

            為什么要搬遷?
            我打開這個編輯頁面花了3個月
            posted @ 2008-01-22 20:54 shifan3 閱讀(1155) | 評論 (1)編輯 收藏
            事實證明,調試黑箱+內核的程序
            RP是關鍵
            posted @ 2007-11-29 16:45 shifan3 閱讀(1267) | 評論 (4)編輯 收藏
            有恒性(G):
            【結果解釋】從測試來看,被試做事茍且敷衍,缺乏奉公守法的精神,缺乏遠大的目標和崇高的理想,對人類社會沒有絕對的責任感,甚至有時不惜知法犯法,不擇手段,不過對于解決實際問題比較有效,不會浪費過多時間與精力。
            【適合職業】藝術家、社會工作者、社會科學家、競技運動員、作家、記者。
            posted @ 2007-11-26 20:53 shifan3 閱讀(982) | 評論 (2)編輯 收藏
            轉載自神的blog
            http://blog.csdn.net/vbvan/archive/2007/10/30/1856481.aspx

            搞掛你的C++編譯器 

            Play  with the compiler是一件很有趣的事情,編譯死循環的程序便是其中之一。讓我們和編譯器一起做游戲吧~

            1、Preprocess

            a、Self Include(GCC only)
            一般的編譯器都有include嵌套層數的限制,所以你需要在適當的時候停止嵌套。利用GCC提供的__INCLUDE_LEVEL__可以很輕松的實現這一點。時間復雜度是na,n是每層的Self Include次數,a是嵌套層數。
            在其它編譯器中可以寫出類似的代碼,只是沒這么簡潔

            #if __INCLUDE_LEVEL__<199
            #include __FILE__
            #include __FILE__
            #endif

            b、Macro Expansion Explosion
            顧名思義,就是讓Preprocess之后的代碼量達到O(2n),比如下例:

            #define F1(x) x,x
            #define F2(x) F1(x),F1(x)
            #define F3(x) F2(x),F2(x)
            #define F4(x) F3(x),F3(x)
            #define F5(x) F4(x),F4(x)
            #define F6(x) F5(x),F5(x)
            #define F7(x) F6(x),F6(x)
            #define F8(x) F7(x),F7(x)
            #define F9(x) F8(x),F8(x)
            #define G1(x) F9(x),F9(x)
            #define G2(x) G1(x),G1(x)
            #define G3(x) G2(x),G2(x)
            #define G4(x) G3(x),G3(x)
            #define G5(x) G4(x),G4(x)
            #define G6(x) G5(x),G5(x)
            #define G7(x) G6(x),G6(x)
            #define G8(x) G7(x),G7(x)
            #define G9(x) G8(x),G8(x)

            int main()
            {
                 G9(1);
            }

            當然,不同的編譯器對預處理結果溢出的處理也不盡相同,一般上面的代碼不會達到預期的目的。GCC會直接出錯,而VC會出ICE(Internal Compiler Error)

            2、Template

            a、嵌套
            類似的,模版也有嵌套層數限制,但是也很容易繞過。
            GCC的某些版本就會被下面的代碼搞掛(VC不會):

            #include <cstddef>
            template <class T>
            struct Test {
                 static const size_t Value=Test<Test<T> >::Value;
            };

            不過利用VC的某個bug(或者說特性),可以很容易的寫出O(na)編譯時間的模版:

            #include <cstddef>

            #define INNER(A3,N3,A2,N2) \
            template<size_t N3>\

            struct A3\
            {\
                 enum {N=A3<N3-1>::N+1};\
            };\
            template<>\

            struct A3<0>\
            {\
                 enum {N=A2<N2-1>::N};\
            };

            #define OUTER(A2,N2,A1,N1,A3,CONTENT) \
            template<size_t N2>\

            struct A2\
            {\
                 CONTENT\
                 \
                 enum {N=A3<N2>::N};\
            };\
            template<>\

            struct A2<0>\
            {\
                 enum {N=A1<N1-1>::N};\
            };

            #define LEVEL2(a,b,c) INNER(A##b,N##b,A##a,N##a)
            #define LEVEL3(a,b,c) OUTER(A##b,N##b,A##a,N##a,A##c,LEVEL2(a##1,b##1,c##1))
            #define LEVEL4(a,b,c) OUTER(A##b,N##b,A##a,N##a,A##c,LEVEL3(a##1,b##1,c##1))
            #define LEVEL5(a,b,c) OUTER(A##b,N##b,A##a,N##a,A##c,LEVEL4(a##1,b##1,c##1))

             template<size_t N1>
            struct A1
            {
                 LEVEL5(1,11,111)
                
            enum {N=A11<N1>::N};
            };

            template<>
            struct A1<0>
            {
                 enum {N=0};
            };

            這里比較有趣的一點是,標準并不允許這樣在模版類里的特化。不知道這個算VC的bug呢還是擴展呢
            A member or a member template may be nested within many enclosing class templates. In an explicit specialization for such a member, the member declaration shall be preceded by a template<> for each enclosing class template that is explicitly specialized
            基于類似的思想,GCC&VC通用的版本也不難寫出。

            b、OLE
            雖然通常模版的編譯時間都是O(n)的,不過很多編譯器的錯誤信息輸出卻是O(n2)的,利用這一點+很長的類名,很容易造成錯誤信息的Output Limit Exceed。比如:

            #define ClassName A 
            template <int N>
            class ClassName
            {
                 enum {Value=ClassName<N-1>::Value};
            };
            int main()
            {
                 int n=ClassName<0>::Value;
            }

            如果我把ClassName改成某個很長的名稱(現代的編譯器都支持很長的變量名),那么錯誤輸出就很容易OLE
            PS:上面的代碼在VC8里會直接出ICE,不過這是VC8的bug。VC2008沒有這樣的問題
            posted @ 2007-11-02 18:08 shifan3 閱讀(1024) | 評論 (0)編輯 收藏
            轉載自神的blog
            http://blog.csdn.net/vbvan/archive/2007/10/30/1857134.aspx

            Flexible C++

            C++是一門非常靈活的語言,只要充分發揮你的想象, 再普通的東西都能玩出新花樣

            1、1~1000求和
            循環?遞歸?再簡單不過的題目了。但是如果不允許你用判斷語句呢?
            如果你熟悉switch的內部實現,那么你很容易想到使用函數指針數組。

            #include <cstdio>

            typedef int (*fun)(int);
            int f1(int i) {return 0;}
            int f2(int i) {fun f[2]={f1,f2}; return i+f[!!i](i-1);}
            int main()
            {
                 printf("%d\n",f2(1000));
            }

            2、輸出1,2,...,100,99,...,2,1
            如果同樣不讓你用判斷語句呢?你仍然可以使用函數指針數組:

            #include <cstdio>

            typedef void (*fun)(int i,int n); 
            void f1(int i,int n);
            void f2(int i,int n);
            void f3(int i,int n);

            void f1(int i,int n)
            {
                 fun f[2]={f1,f2};

                 printf("%d\n",i);
                 f[i+1==n](i+1,n);
            }

            void f2(int i,int n)
            {
                 fun f[2]={f2,f3};
                 printf("%d\n",i);
                 f[i==1](i-1,n);
            }

            void f3(int i,int n) {}

            int main()
            {
                 f1(1,100);
            }

            不過我們有更簡潔的方法。
            短路算法和逗號表達式粉墨登場了,一行搞定~

            #include <cstdio>

            void f(int i,int n)
            {
                 printf("%d\n",i),(i<n)&&(f(i+1,n),printf("%d\n",i));
            }

            int main()
            {
                 f(1,100);
            }

            posted @ 2007-11-02 18:05 shifan3 閱讀(1364) | 評論 (3)編輯 收藏

            江城子

            黃葉滿地秋已涼,豪氣減,怨氣長?
            長子有感,我為畢業狂。
            狂風逐葉又經年,白日短,愁日長?
            長淚沾襟形容慚,順者昌,逆者亡?
            亡命玉泉,敢嗜血豺狼。
            狼子野心不曾想:畢業難,就業黃?

            by boylaugh
            posted @ 2007-10-30 00:53 shifan3 閱讀(1056) | 評論 (2)編輯 收藏

            發信人: xiaoheng (我的一班我的愛), 板面: C++
            標  題: Re: 父類的方法能否使用子類的特有屬性
            發信站: 飄渺水云間 (Mon Aug 27 22:12:27 2007), 站內信件

            我在公司只聽說生女兒的,沒有聽說生兒子的。中國、印度、美國都一樣。

            【 在 shifan (Au revoir, mes amis) 的大作中提到: 】
            : 應該說,老爸在沒XX的時候,也無法決定后代是男是女
            : 【 在 morningcs (BG5HLI·"鎏"金歲月·CS0306 Forever) 的大作中提到: 】
            : : 你老爸在你小的時候也不知道你以后有啥特長

            posted @ 2007-08-27 22:22 shifan3 閱讀(1087) | 評論 (3)編輯 收藏
            必先勞其筋骨

            原來被開水燙是這個感覺。。。
            posted @ 2007-08-26 21:38 shifan3 閱讀(1063) | 評論 (3)編輯 收藏
            材料 五花肉(或其他半肥瘦肉,網上眾說紛紜-,-) 蒜苗

            1。用水煮肉至肉熟皮軟,撈出冷卻切片
            2。切蒜苗(菱形片)
            3。豆絲(少許)、豆瓣(一勺或2勺)、甜醬(約一勺),鹽(適量),混合后用油炒出香味
            4。放入肉片,炒至發卷
            5。放入蒜苗,炒熟后適量放味精等調料


            ref http://news.xinhuanet.com/food/2004-09/14/content_1979737.htm
            posted @ 2007-08-02 21:00 shifan3 閱讀(1252) | 評論 (7)編輯 收藏
            僅列出標題  下一頁
            久久精品国产AV一区二区三区| 久久99精品国产| 久久久久久免费视频| 亚洲AV日韩AV天堂久久| 国产亚洲婷婷香蕉久久精品| 久久久中文字幕| 97视频久久久| 久久r热这里有精品视频| 青青草国产97免久久费观看| 少妇内射兰兰久久| 久久综合久久伊人| 久久久国产乱子伦精品作者| 久久久久亚洲AV成人网人人软件| 国内精品人妻无码久久久影院导航 | Xx性欧美肥妇精品久久久久久| 欧美久久天天综合香蕉伊| 国产人久久人人人人爽| 少妇被又大又粗又爽毛片久久黑人| 精品蜜臀久久久久99网站| 欧美午夜精品久久久久久浪潮| 国产V亚洲V天堂无码久久久| 麻豆国内精品久久久久久| 国产亚洲婷婷香蕉久久精品| 亚洲国产精品无码久久久不卡| 久久国产精品无码网站| 久久国产精品久久| 久久ZYZ资源站无码中文动漫| 久久人人爽人人爽人人片av麻烦| 久久久久99精品成人片三人毛片| AV无码久久久久不卡网站下载| 午夜天堂av天堂久久久| 国产精品久久久久蜜芽| 久久乐国产综合亚洲精品| 欧美久久天天综合香蕉伊| 久久亚洲国产成人影院网站| 久久亚洲电影| 国产精品久久久久蜜芽| 亚洲日本久久久午夜精品| 一级A毛片免费观看久久精品| 久久久久久A亚洲欧洲AV冫| 伊人久久大香线蕉成人|