那誰的技術博客
感興趣領域:高性能服務器編程,存儲,算法,Linux內核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數據加載中……
Modern C++ Design(MCD)學習筆記 && 測試代碼(一)
MCD里面給我們展現了許多高階的C++ template技巧,大部分都是天才級別的人才能想出來的,與此同時,這些技巧也稍顯前衛了,至少根據我對國內C++程序員的了解,能把STL玩的很好的已經少見了,并且里面的大部分技巧是在“挑戰編譯器”。
但是,我還是決定好好把這本書看完,一邊看一邊摘錄書中以及loki庫中的代碼進行測試,權當開闊自己的視野。
一.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
;
}
這個東東的技巧在于:定義一個模版類,這個模版的模版參數是bool類型,對true的特化模版類進行了定義,而false的特化類沒有定義,在使用的時候把需要斷言的表達式作為模版參數來初始化這個模版類,如果為false,因為false的特化類沒有定義,此時編譯器會報錯。
注意:這里的斷言是在編譯期進行的,與一般的運行時斷言有區別。
未完待續....
posted on 2007-02-04 15:53
那誰
閱讀(1675)
評論(1)
編輯
收藏
引用
所屬分類:
C\C++
評論
#
re: Modern C++ Design(MCD)學習筆記 && 測試代碼(一)
回復
更多評論
加油,我以看完了。不好搞明白的東西。多寫代碼,即使是把它的代碼一個一個
的重復的寫一邊和編譯一邊也是非常有意的。
推薦看看 c++ template 中文版(要是能看懂英文當然更是號)。這本書對模板技術的表達的還是非常全面的。
boost中的MPL庫是用來完成編譯器編程的,非常的不錯,有空可以研究一下那個里面的代碼。boost的基礎就是模板。
stl并不是單純的用了模板技術,而是用那個技術實現了范型,個人覺得用模板技術和范型思想,完全是對傳統的面向對象技術的顛覆。非常的時尚
2007-02-04 23:44 |
walkspeed
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
C++的流設計很糟糕
解讀google C++ code style談對C++的理解
Callback在C\C++中的實現
自己實現的memcpy
服務器公共庫開發--線程安全的singleton類, 可配置的線程鎖管理類
服務器公共庫開發--讀取ini文件格式的類
如何使用位操作得到大于N且為2的次方的最小的數
(C++)一個愚蠢的錯誤
研究了一下SGI STL的內存算法
memcache內存池的設計原理
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 那誰
導航
C++博客
首頁
聯系
聚合
管理
<
2007年3月
>
日
一
二
三
四
五
六
25
26
27
28
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)
操作系統(1)
(rss)
讀書筆記(3)
(rss)
服務器設計(42)
(rss)
腳本語言(1)
(rss)
經驗教訓(4)
(rss)
其他(10)
(rss)
設計模式(24)
(rss)
算法與數據結構(48)
(rss)
圖形學(1)
(rss)
網絡編程(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
文件
關于我
我的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采用的網絡模型
很好的文章,值得分享。
--紐約網站設計
2.?re: 常見設計模式的解析和實現(C++)文檔及源碼打包下載
評論內容較長,點擊標題查看
--殘陽叢林
3.?re: libevent事件處理框架分析
@hailong
拿走后,堆的恢復是logn
--jiao
4.?re: 從半同步-半異步模式談服務器的設計
學習服務器的一些代碼模式。
--王小亮
5.?re: 讓libevent支持多線程
剛開始以為有個新的方法可以實現多線程。。。。其實就試類似pipe的方式, memcache就是這樣做的,可以參考一下
--fly2010love
閱讀排行榜
1.?同步/異步與阻塞/非阻塞的區別(53090)
2.?libevent事件處理框架分析(45258)
3.?epoll學習筆記(41162)
4.?解讀google C++ code style談對C++的理解(38167)
5.?集成libevent,google protobuf的RPC框架(27483)
6.?常見設計模式的解析和實現(C++)文檔及源碼打包下載(24076)
7.?讓libevent支持多線程(23611)
8.?一個關于臨時對象和虛擬析構函數的問題(22331)
9.?epoll為什么這么快(20300)
10.?二叉樹遍歷算法集合(前中后序遍歷的遞歸和非遞歸算法,層序遍歷算法)(20249)
11.?Callback在C\C++中的實現(20141)
12.?二分查找算法(迭代和遞歸版本)(18332)
13.?談目前項目組的代碼提交制度(17972)
14.?Linux下面的線程鎖,條件變量以及信號量的使用(15679)
15.?C++的流設計很糟糕(14789)
16.?二分查找學習札記(14300)
17.?memcached采用的網絡模型(13961)
18.?紅黑樹的實現源碼(第二次修訂版)(13686)
19.?多進程服務器中,epoll的創建應該在創建子進程之后(12709)
20.?第一個socket程序-C\S模式的文件傳輸程序(12270)
21.?使用tolua++創建基于C\C++語言的lua腳本(12091)
22.?博客遷移(11695)
23.?從半同步-半異步模式談服務器的設計(11597)
24.?Lighty與Nginx的比較分析(11580)
25.?Btree算法實現代碼(11579)
26.?向德國人低頭(11533)
27.?epoll相關資料整理(11285)
28.?把二分查找算法寫正確需要注意的地方(11158)
29.?程序設計經驗總結(10251)
30.?我的項目Makefile文件模板(10175)
31.?帶超時機制的DNS解析API(9566)
32.?方法與工具(9418)
33.?自己設想的一個IM服務器的架構(9201)
評論排行榜
1.?常見設計模式的解析和實現(C++)文檔及源碼打包下載(90)
国产成人精品久久综合
|
久久精品a亚洲国产v高清不卡
|
9999国产精品欧美久久久久久
|
韩国三级中文字幕hd久久精品
|
日本亚洲色大成网站WWW久久
|
久久国产午夜精品一区二区三区
|
中文字幕无码久久精品青草
|
色欲综合久久中文字幕网
|
69国产成人综合久久精品
|
久久久精品视频免费观看
|
久久国产精品99国产精
|
久久无码国产
|
国内精品久久久久
|
久久综合亚洲色一区二区三区
|
久久国产亚洲高清观看
|
久久精品夜色噜噜亚洲A∨
|
久久久久亚洲精品无码网址
|
久久精品亚洲男人的天堂
|
久久亚洲精品成人无码网站
|
久久国产精品成人免费
|
中文精品99久久国产
|
久久这里只有精品首页
|
91精品国产高清91久久久久久
|
亚洲国产天堂久久综合
|
九九热久久免费视频
|
成人久久综合网
|
99久久无码一区人妻a黑
|
免费精品久久天干天干
|
性做久久久久久久久久久
|
国内精品久久久久久久久
|
99热精品久久只有精品
|
久久亚洲精品无码AV红樱桃
|
精品久久久无码21p发布
|
久久国产AVJUST麻豆
|
中文国产成人精品久久亚洲精品AⅤ无码精品
|
成人a毛片久久免费播放
|
精品久久香蕉国产线看观看亚洲
|
欧美牲交A欧牲交aⅴ久久
|
久久久久久国产精品无码超碰
|
亚洲午夜久久久久妓女影院
|
久久无码中文字幕东京热
|