那誰的技術(shù)博客
感興趣領(lǐng)域:高性能服務(wù)器編程,存儲,算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數(shù)據(jù)加載中……
Modern C++ Design(MCD)學(xué)習筆記 && 測試代碼(一)
MCD里面給我們展現(xiàn)了許多高階的C++ template技巧,大部分都是天才級別的人才能想出來的,與此同時,這些技巧也稍顯前衛(wèi)了,至少根據(jù)我對國內(nèi)C++程序員的了解,能把STL玩的很好的已經(jīng)少見了,并且里面的大部分技巧是在“挑戰(zhàn)編譯器”。
但是,我還是決定好好把這本書看完,一邊看一邊摘錄書中以及l(fā)oki庫中的代碼進行測試,權(quán)當開闊自己的視野。
一.compile assert編譯器斷言技巧
//
?以下是書中的代碼
template
<
bool
>
?
struct
?CompileTimeError;
template
<>
?
struct
?CompileTimeError
<
true
>
{}
;
#define
?STATIC_CHECK(expr)??\
????(CompileTimeError
<
?(expr)?
!=
?
0
>
()?)
template
<
bool
>
?
struct
?CompileTimeChecker
{
????CompileTimeChecker(
);
}
;
template
<>
?
struct
?CompileTimeChecker
<
false
>
?
{}
;
#define
?STATIC_CHECK_MSG(expr,?msg)?\
????
{\
????????
class
?ERROR_##msg?
{}
;\
????????(
void
)
sizeof
(CompileTimeChecker
<
(expr)
>
?(ERROR_##msg()));\
????}
//
?以下是loki中的代碼
namespace
?Loki
{
????template
<
int
>
?
struct
?CompileTimeError;
????template
<>
?
struct
?CompileTimeError
<
true
>
?
{}
;
}
#define
?STATIC_CHECK_LOKI(expr,?msg)?\
{?Loki::CompileTimeError
<
((expr)?
!=
?
0
)
>
?ERROR_##msg;?(
void
)ERROR_##msg;}
?
int
?main(
int
?argc,?
char
?
*
argv[])
{
????
//
?gcc不能編譯,VC7編譯通過
????STATIC_CHECK(
1
);
????
//
?gcc,VC7都不能編譯
????
//
STATIC_CHECK_MSG(1,?Error_Msg);
????
//
?gcc,VC7都能編譯
????STATIC_CHECK_LOKI(
1
,?Error_Msg);
????
return
?
0
;
}
這個東東的技巧在于:定義一個模版類,這個模版的模版參數(shù)是bool類型,對true的特化模版類進行了定義,而false的特化類沒有定義,在使用的時候把需要斷言的表達式作為模版參數(shù)來初始化這個模版類,如果為false,因為false的特化類沒有定義,此時編譯器會報錯。
注意:這里的斷言是在編譯期進行的,與一般的運行時斷言有區(qū)別。
未完待續(xù)....
posted on 2007-02-04 15:53
那誰
閱讀(1674)
評論(1)
編輯
收藏
引用
所屬分類:
C\C++
評論
#
re: Modern C++ Design(MCD)學(xué)習筆記 && 測試代碼(一)
回復(fù)
更多評論
加油,我以看完了。不好搞明白的東西。多寫代碼,即使是把它的代碼一個一個
的重復(fù)的寫一邊和編譯一邊也是非常有意的。
推薦看看 c++ template 中文版(要是能看懂英文當然更是號)。這本書對模板技術(shù)的表達的還是非常全面的。
boost中的MPL庫是用來完成編譯器編程的,非常的不錯,有空可以研究一下那個里面的代碼。boost的基礎(chǔ)就是模板。
stl并不是單純的用了模板技術(shù),而是用那個技術(shù)實現(xiàn)了范型,個人覺得用模板技術(shù)和范型思想,完全是對傳統(tǒng)的面向?qū)ο蠹夹g(shù)的顛覆。非常的時尚
2007-02-04 23:44 |
walkspeed
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
C++的流設(shè)計很糟糕
解讀google C++ code style談對C++的理解
Callback在C\C++中的實現(xiàn)
自己實現(xiàn)的memcpy
服務(wù)器公共庫開發(fā)--線程安全的singleton類, 可配置的線程鎖管理類
服務(wù)器公共庫開發(fā)--讀取ini文件格式的類
如何使用位操作得到大于N且為2的次方的最小的數(shù)
(C++)一個愚蠢的錯誤
研究了一下SGI STL的內(nèi)存算法
memcache內(nèi)存池的設(shè)計原理
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 那誰
導(dǎo)航
C++博客
首頁
聯(lián)系
聚合
管理
<
2009年10月
>
日
一
二
三
四
五
六
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
公告
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(71)
給我留言
查看公開留言
查看私人留言
隨筆分類
(264)
avidya(1)
(rss)
C\C++(21)
(rss)
ccache(8)
(rss)
CGL(5)
(rss)
eventrpc(1)
(rss)
gdb(2)
(rss)
libevent(2)
(rss)
lighttpd(10)
(rss)
linux kernel(7)
(rss)
Linux/Unix(32)
(rss)
memcached(2)
(rss)
mktags(4)
(rss)
Nginx(5)
(rss)
Perl(3)
(rss)
tokyo cabinet(5)
(rss)
操作系統(tǒng)(1)
(rss)
讀書筆記(3)
(rss)
服務(wù)器設(shè)計(42)
(rss)
腳本語言(1)
(rss)
經(jīng)驗教訓(xùn)(4)
(rss)
其他(10)
(rss)
設(shè)計模式(24)
(rss)
算法與數(shù)據(jù)結(jié)構(gòu)(48)
(rss)
圖形學(xué)(1)
(rss)
網(wǎng)絡(luò)編程(22)
(rss)
隨筆檔案
(210)
2010年8月 (1)
2010年7月 (3)
2010年6月 (2)
2010年5月 (1)
2010年4月 (2)
2010年3月 (1)
2010年1月 (5)
2009年12月 (7)
2009年11月 (3)
2009年10月 (7)
2009年9月 (2)
2009年8月 (2)
2009年7月 (1)
2009年6月 (3)
2009年5月 (2)
2009年4月 (7)
2009年3月 (2)
2009年2月 (2)
2009年1月 (5)
2008年12月 (1)
2008年11月 (2)
2008年10月 (6)
2008年9月 (12)
2008年8月 (11)
2008年7月 (5)
2008年6月 (2)
2008年4月 (3)
2008年3月 (3)
2008年2月 (1)
2008年1月 (1)
2007年12月 (3)
2007年11月 (3)
2007年8月 (1)
2007年7月 (2)
2007年6月 (2)
2007年5月 (9)
2007年4月 (1)
2007年3月 (8)
2007年2月 (3)
2007年1月 (5)
2006年12月 (4)
2006年11月 (3)
2006年10月 (5)
2006年9月 (4)
2006年8月 (13)
2006年7月 (28)
2006年4月 (1)
2006年3月 (4)
2006年2月 (4)
2006年1月 (1)
2005年12月 (1)
相冊
ccache
lighttpd
tokyo cabinet
文件
關(guān)于我
我的google reader share
我的google reader share
開源項目
libevent
lighttpd
memcached
PCRE for Windows (Win32)
sqlite
STLFilt
論壇
ChinaUnix
OldLinux
朋友
cugb_cat
Edengundam
win_hate
ypxing
老羅
搜索
最新評論
1.?re: memcached采用的網(wǎng)絡(luò)模型
很好的文章,值得分享。
--紐約網(wǎng)站設(shè)計
2.?re: 常見設(shè)計模式的解析和實現(xiàn)(C++)文檔及源碼打包下載
評論內(nèi)容較長,點擊標題查看
--殘陽叢林
3.?re: libevent事件處理框架分析
@hailong
拿走后,堆的恢復(fù)是logn
--jiao
4.?re: 從半同步-半異步模式談服務(wù)器的設(shè)計
學(xué)習服務(wù)器的一些代碼模式。
--王小亮
5.?re: 讓libevent支持多線程
剛開始以為有個新的方法可以實現(xiàn)多線程。。。。其實就試類似pipe的方式, memcache就是這樣做的,可以參考一下
--fly2010love
閱讀排行榜
1.?同步/異步與阻塞/非阻塞的區(qū)別(53088)
2.?libevent事件處理框架分析(45256)
3.?epoll學(xué)習筆記(41161)
4.?解讀google C++ code style談對C++的理解(38165)
5.?集成libevent,google protobuf的RPC框架(27481)
6.?常見設(shè)計模式的解析和實現(xiàn)(C++)文檔及源碼打包下載(24074)
7.?讓libevent支持多線程(23609)
8.?一個關(guān)于臨時對象和虛擬析構(gòu)函數(shù)的問題(22330)
9.?epoll為什么這么快(20299)
10.?二叉樹遍歷算法集合(前中后序遍歷的遞歸和非遞歸算法,層序遍歷算法)(20249)
11.?Callback在C\C++中的實現(xiàn)(20141)
12.?二分查找算法(迭代和遞歸版本)(18331)
13.?談目前項目組的代碼提交制度(17971)
14.?Linux下面的線程鎖,條件變量以及信號量的使用(15678)
15.?C++的流設(shè)計很糟糕(14788)
16.?二分查找學(xué)習札記(14299)
17.?memcached采用的網(wǎng)絡(luò)模型(13959)
18.?紅黑樹的實現(xiàn)源碼(第二次修訂版)(13685)
19.?多進程服務(wù)器中,epoll的創(chuàng)建應(yīng)該在創(chuàng)建子進程之后(12708)
20.?第一個socket程序-C\S模式的文件傳輸程序(12268)
21.?使用tolua++創(chuàng)建基于C\C++語言的lua腳本(12089)
22.?博客遷移(11694)
23.?從半同步-半異步模式談服務(wù)器的設(shè)計(11596)
24.?Lighty與Nginx的比較分析(11580)
25.?Btree算法實現(xiàn)代碼(11578)
26.?向德國人低頭(11531)
27.?epoll相關(guān)資料整理(11283)
28.?把二分查找算法寫正確需要注意的地方(11156)
29.?程序設(shè)計經(jīng)驗總結(jié)(10249)
30.?我的項目Makefile文件模板(10175)
31.?帶超時機制的DNS解析API(9565)
32.?方法與工具(9417)
33.?自己設(shè)想的一個IM服務(wù)器的架構(gòu)(9199)
評論排行榜
1.?常見設(shè)計模式的解析和實現(xiàn)(C++)文檔及源碼打包下載(90)
精品久久久无码人妻中文字幕豆芽
|
亚洲精品无码久久久久久
|
少妇人妻综合久久中文字幕
|
99精品久久久久久久婷婷
|
国产精品岛国久久久久
|
国产精品99久久99久久久
|
久久天堂AV综合合色蜜桃网
|
亚洲人成精品久久久久
|
日韩久久久久久中文人妻
|
亚洲av日韩精品久久久久久a
|
亚洲中文字幕无码久久2017
|
熟妇人妻久久中文字幕
|
亚洲精品国精品久久99热一
|
亚洲AV无码久久精品色欲
|
国产成人精品综合久久久
|
亚洲午夜久久久影院伊人
|
精品国产一区二区三区久久久狼
|
久久精品国产亚洲AV无码娇色
|
国产精品久久久久…
|
久久综合狠狠综合久久激情
|
99久久精品免费
|
久久亚洲国产最新网站
|
国产精品99精品久久免费
|
精品久久久久久久久久久久久久久
|
国产福利电影一区二区三区久久老子无码午夜伦不
|
91麻精品国产91久久久久
|
久久精品无码一区二区三区免费
|
亚洲精品午夜国产va久久
|
久久无码人妻一区二区三区
|
久久国产高潮流白浆免费观看
|
精品无码久久久久久午夜
|
久久精品二区
|
久久久久久久久无码精品亚洲日韩
|
久久水蜜桃亚洲av无码精品麻豆
|
996久久国产精品线观看
|
久久天天躁狠狠躁夜夜不卡
|
亚洲中文字幕久久精品无码喷水
|
国产精品永久久久久久久久久
|
色欲综合久久躁天天躁蜜桃
|
久久精品成人影院
|
99久久无色码中文字幕
|