那誰的技術(shù)博客
感興趣領(lǐng)域:高性能服務(wù)器編程,存儲,算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數(shù)據(jù)加載中……
Modern C++ Design(MCD)學習筆記 && 測試代碼(一)
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
那誰
閱讀(1693)
評論(1)
編輯
收藏
引用
所屬分類:
C\C++
評論
#
re: Modern C++ Design(MCD)學習筆記 && 測試代碼(一)
回復
更多評論
加油,我以看完了。不好搞明白的東西。多寫代碼,即使是把它的代碼一個一個
的重復的寫一邊和編譯一邊也是非常有意的。
推薦看看 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)站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 那誰
導航
C++博客
首頁
聯(lián)系
聚合
管理
<
2009年7月
>
日
一
二
三
四
五
六
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
8
公告
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(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)驗教訓(4)
(rss)
其他(10)
(rss)
設(shè)計模式(24)
(rss)
算法與數(shù)據(jù)結(jié)構(gòu)(48)
(rss)
圖形學(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
拿走后,堆的恢復是logn
--jiao
4.?re: 從半同步-半異步模式談服務(wù)器的設(shè)計
學習服務(wù)器的一些代碼模式。
--王小亮
5.?re: 讓libevent支持多線程
剛開始以為有個新的方法可以實現(xiàn)多線程。。。。其實就試類似pipe的方式, memcache就是這樣做的,可以參考一下
--fly2010love
閱讀排行榜
1.?同步/異步與阻塞/非阻塞的區(qū)別(53155)
2.?libevent事件處理框架分析(45303)
3.?epoll學習筆記(41223)
4.?解讀google C++ code style談對C++的理解(38228)
5.?集成libevent,google protobuf的RPC框架(27526)
6.?常見設(shè)計模式的解析和實現(xiàn)(C++)文檔及源碼打包下載(24150)
7.?讓libevent支持多線程(23638)
8.?一個關(guān)于臨時對象和虛擬析構(gòu)函數(shù)的問題(22346)
9.?epoll為什么這么快(20331)
10.?二叉樹遍歷算法集合(前中后序遍歷的遞歸和非遞歸算法,層序遍歷算法)(20257)
11.?Callback在C\C++中的實現(xiàn)(20216)
12.?二分查找算法(迭代和遞歸版本)(18363)
13.?談目前項目組的代碼提交制度(18022)
14.?Linux下面的線程鎖,條件變量以及信號量的使用(15699)
15.?C++的流設(shè)計很糟糕(14870)
16.?二分查找學習札記(14330)
17.?memcached采用的網(wǎng)絡(luò)模型(13987)
18.?紅黑樹的實現(xiàn)源碼(第二次修訂版)(13758)
19.?多進程服務(wù)器中,epoll的創(chuàng)建應(yīng)該在創(chuàng)建子進程之后(12763)
20.?第一個socket程序-C\S模式的文件傳輸程序(12311)
21.?使用tolua++創(chuàng)建基于C\C++語言的lua腳本(12122)
22.?博客遷移(11738)
23.?從半同步-半異步模式談服務(wù)器的設(shè)計(11671)
24.?Lighty與Nginx的比較分析(11611)
25.?Btree算法實現(xiàn)代碼(11607)
26.?向德國人低頭(11583)
27.?epoll相關(guān)資料整理(11303)
28.?把二分查找算法寫正確需要注意的地方(11184)
29.?程序設(shè)計經(jīng)驗總結(jié)(10320)
30.?我的項目Makefile文件模板(10213)
31.?帶超時機制的DNS解析API(9601)
32.?方法與工具(9428)
33.?自己設(shè)想的一個IM服務(wù)器的架構(gòu)(9221)
評論排行榜
1.?常見設(shè)計模式的解析和實現(xiàn)(C++)文檔及源碼打包下載(90)
av无码久久久久不卡免费网站
|
99久久做夜夜爱天天做精品
|
国产精品久久毛片完整版
|
热久久这里只有精品
|
精品无码久久久久久久久久
|
欧美久久综合性欧美
|
久久久久香蕉视频
|
精品久久久无码人妻中文字幕豆芽
|
99久久国产亚洲高清观看2024
|
久久人人爽人人人人爽AV
|
日产精品久久久一区二区
|
久久久WWW免费人成精品
|
久久精品水蜜桃av综合天堂
|
亚洲国产精品无码久久青草
|
久久国产精品-国产精品
|
久久综合综合久久综合
|
精品久久久久久无码中文字幕
|
久久精品国产99久久无毒不卡
|
久久99久久99精品免视看动漫
|
国产精品久久久久一区二区三区
|
亚洲国产精品高清久久久
|
色婷婷久久久SWAG精品
|
国内精品久久久久久不卡影院
|
亚洲乱码精品久久久久..
|
久久精品免费全国观看国产
|
国内精品久久久久久中文字幕
|
狠色狠色狠狠色综合久久
|
伊人久久大香线蕉av不卡
|
日本WV一本一道久久香蕉
|
久久亚洲2019中文字幕
|
午夜精品久久久久成人
|
综合久久精品色
|
18禁黄久久久AAA片
|
香蕉久久夜色精品国产尤物
|
久久男人AV资源网站
|
日本欧美国产精品第一页久久
|
久久久久国色AV免费观看
|
中文字幕亚洲综合久久菠萝蜜
|
久久久www免费人成精品
|
久久久久人妻一区精品性色av
|
久久天天躁狠狠躁夜夜avapp
|