青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

復雜結構體的存取器

Posted on 2009-02-19 23:43 S.l.e!ep.¢% 閱讀(400) 評論(0)  編輯 收藏 引用 所屬分類: C++

在《C宏——智者的利刃,愚者的惡夢! 》一文中,提到了一種使用宏的方式 —— “例一、用C宏,書寫代碼更簡潔”。
《C宏——智者的利刃,愚者的惡夢! 》: http://www.vckbase.com/document/viewdoc/?id=1454
《C宏——智者的利刃,愚者的惡夢! 》: http://blog.vckbase.com/smileonce/archive/2005/03/27/4081.html

本文章分別給出C++和C中不使用宏的實現方式。


?

首先,書寫代碼更簡潔是否是優點?
有興趣的讀者請看看《設計Qt風格的C++API》一文中“便利陷阱” (The Convenience Trap) 一節。
中文: http://blog.csdn.net/TopLanguage/archive/2008/02/21/2111467.aspx
英文: http://doc.trolltech.com/qq/qq13-apis.html

【永遠記住代碼一次寫就,之后需要不斷的閱讀并理解。】
【Keep in mind that code is written more than once but has to be understood over and over again.】


?

如果真要達到笑笑文中——【mbuf的屬性,完全可以壓扁到一個平面上去看】——這個目的,除了宏,也是有其他方法的。

在這里說明一下,笑笑在文中并沒有給出struct mbuf的完整定義。
我沒有linux,Cygwin也刪掉了,安裝挺麻煩的……
順藤摸瓜的下載了一部分文件:
http://opengrok.creo.hu/dragonfly/xref/src/sys/sys/mbuf.h
http://opengrok.creo.hu/dragonfly/xref/src/sys/sys/param.h
http://opengrok.creo.hu/dragonfly/xref/src/sys/net/netisr.h
http://opengrok.creo.hu/dragonfly/xref/src/sys/net/netmsg.h
http://opengrok.creo.hu/dragonfly/xref/src/sys/sys/thread.h
http://opengrok.creo.hu/dragonfly/xref/src/sys/sys/msgport.h
企圖拼出一個完整的struct mbuf定義,但實在太麻煩,這里就放棄了 ……

所以只用一個簡單的例子來說明如何不使用宏來達到這一目的。
當然,也會說明如果結構體更復雜該如何擴展。


?


/* *?structure?definition? */

/* ?simple?Point?&?Size?structure? */
typedef?
struct ?Point_? {
????
int ?x;
????
int ?y;
}
?Point;

typedef?
struct ?Size_? {
????
int ?width;
????
int ?height;
}
?Size;

/* *?complex?Rect?structrue? */
typedef?
struct ?Rect_? {
????Point?offset;
????Size?size;
}
?Rect;




C++方案:

?


namespace?cpp?{

????
class?RectAccessor?{
????
public:
????????RectAccessor(Rect
&?r)
????????????:x(r.offset.x)
????????????,y(r.offset.y)
????????????,width(r.size.width)
????????????,height(r.size.width)
????????
{??}
????
public:
????????
int&?x;
????????
int&?y;
????????
int&?width;
????????
int&?height;
????}
;

????
void?test(int?(&arr)[4],Rect*?r)?{
????????RectAccessor?ac(
*r);
????????
//?同一平面
????????ac.x?=?arr[0];
????????ac.y?
=?arr[1];
????????ac.width?
=?arr[2];
????????ac.height?
=?arr[3];
????????printf(
"%d?%d?%d?%d\n",ac.x,ac.y,ac.width,ac.height);
????}

}


const怎么辦?
(對const的考慮,C++程序員總是比C程序員要多一點,不是嗎?)


/**?const?accessor?*/
//?再定義一個const存取器不就完了?
class?ConstRectAccessor?{?/**/?};

//如果覺得這樣名字不統一,不好看,也可以這樣
template<bool?is_constant>
class?RectAccessor;
template
<>
class?RectAccessor<false>?{?/*?同上面那個RectAccessor?*/?};
class?RectAccessor<true>?{?/*?同上面那個ConstRectAccessor?*/?};


對更復雜的結構體,該方法的擴展是很容易的事情:在構造函數的成員初始化列表里寫就是了。



C呢?是不是只能使用宏?當然不是。
C的方案:

?


namespace?c?{

????typedef?union?RectAccessor_
????
{
????????
struct?S1?{
????????????
int?x;
????????????
int?y;
????????????
int?width;
????????????
int?height;
????????}
;
????????
struct?S2?{
????????????Point?offset;
????????????Size?size;
????????}
;
????????Rect?rect;

????}
?RectAccessor;

????__declspec(noinline)?
void?test(int?(&arr)[4],Rect*?r)?{
????????RectAccessor
*?ac?=?(RectAccessor*)?r;
????????
//?同一平面
????????ac->x?=?arr[0];
????????ac
->y?=?arr[1];
????????ac
->width?=?arr[2];
????????ac
->height?=?arr[3];
????????printf(
"%d?%d?%d?%d\n",ac->x,ac->y,ac->width,ac->height);
????}

}


對const, 轉型的時候,注意使用合適的指針類型就可以了。

想更復雜的結構體擴展:
如果對上面的方案不理解,甚至對mbuf都不理解,最好還是老老實實的使用全名。
永遠記得,代碼讀的次數比寫的次數多!

上面的方案,是利用了一個特性,叫“匿名聯合”還別的什么東東。
含義大概是這樣:


union?U?{
??
struct?/**?anonymous?*/?{
?????t11?v11;
?????t12?v12;
?????
/*?more?members?*/
??}
?/**?anonymous?*/;
??
struct?/**?anonymous?*/?{
?????t21?v21;
?????t22?v22;
?????
/*?more?members?*/
??}
?/**?anonymous?*/;
??
/**?more?structures?*/
}
;

/*?那么就可以*/
U?u;
u.v11;?u.v12;?u.v21;

?



經測試,上面兩種方案,在VC8 O2優化下,生成的機器碼同不使用Accessor完全一致
GCC就沒有測試了,看不懂它的匯編……

?


對宏的方案(也就是mbuf.h中提供的)的改進:
簡直無法想象!居然在 頭文件定義如此 普遍小寫名字!

?


/**?mbuf_accessor_define.h?*/
#define????m_next????????m_hdr.mh_next
#define????m_len????????m_hdr.mh_len
#define????m_data????????m_hdr.mh_data
#define????m_type????????m_hdr.mh_type
#define????m_flags????????m_hdr.mh_flags
#define????m_nextpkt????m_hdr.mh_nextpkt
#define????m_pkthdr????M_dat.MH.MH_pkthdr
#define????m_ext????????M_dat.MH.MH_dat.MH_ext
#define????m_pktdat????M_dat.MH.MH_dat.MH_databuf
#define????m_dat????????M_dat.M_databuf

/**?mbuf_accessor_undef.h?*/
#undef????m_next
#undef????m_len
#undef????m_data
#undef????m_type
#undef????m_flags
#undef????m_nextpkt
#undef????m_pkthdr
#undef????m_ext
#undef????m_pktdat
#undef????m_dat

/*?需要的時候?*/
#include?
<mbuf_accessor_define.h>
/*?使用簡寫?*/
/*?使用簡寫?*/
/*?使用簡寫?*/
/*?然后立刻取消定義?*/
#include?
<mbuf_accessor_undef.h>

?



PS:C程序員總說C++的語言特性有心智包袱,難道宏就不算心智包袱?

?

物理老師從來都是這么寫:???????????? ?F = M*A;
沒見任何一個物理老師會這么寫:? F = multiply(M,A);
如果是,請立刻和同學打賭說他是程序員,而且很有可能是C程序員。

hp_int i1,i2,i3;
// ...
數學老師也總是這么寫: hp_int icpp = i1 + i2 * i3;

不會有數學老師這么寫:
hp_int ic;
hp_assign(&i2,&ic);
hp_multiply(&i3,&ic);
hp_plus(&i1,&ic);

或者這么寫:
hp_plus(&i1,hp_multiply(&i3,hp_assgin(&i2,&ic) ) );

(hp —— 高精度,? 對矩陣也是同樣)


C程序員說,不知道 string s = s1 + s2 + s3;背后做了什么。
C++程序員說,由庫決定。
C程序員說,我對庫中那些精巧的技術不感興趣(不熟悉,不愿意學)。
C++程序員說,就對宏技術感興趣?
C程序員說,宏效率高。
C++程序員說, 如果 string s = s1 + s2 + s3;可以實現得比 strcat(strcat(strcat(....) 效率更高,你信不信?
C++程序員再說,如果可以自然的寫出hp_int icpp = i1 + i2 * i3;有正確的運算優先級,效率與hp_plus(&i1,hp_multiply(&i3,hp_assgin(&i2,&ic) ) );等同,你還愿意用后者?
C程序員說,那些實現都是心智包袱,我不喜歡。
C++程序員說,宏算不算心智包袱?你怎么就喜歡了?


總之,這只是一種不愿學習的心態,一種手拿錘子見什么都是釘子的心態。
Linus年紀也不算大……才40歲…… 哎……

posted on 2009-02-19 21:48 OwnWaterloo 閱讀(90) 評論(0) ?編輯?收藏引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩综合另类| 国产一区二区中文字幕免费看| 亚洲三级毛片| 亚洲人成人99网站| 欧美电影电视剧在线观看| 日韩午夜在线电影| 一本色道久久加勒比精品| 国产精品视频一区二区高潮| 久久成年人视频| 久久久之久亚州精品露出| 亚洲福利在线看| 99re热精品| 国产日韩精品在线播放| 欧美大香线蕉线伊人久久国产精品| 欧美a级一区二区| 亚洲一区二区三区中文字幕在线| 亚洲一区欧美一区| 亚洲高清在线观看| 中文精品在线| 黄色日韩精品| 亚洲精品中文字幕在线| 国产欧美一区二区三区在线老狼 | 好男人免费精品视频| 欧美黄色成人网| 欧美日韩综合精品| 久久这里有精品视频| 欧美日韩不卡合集视频| 久久久精品一品道一区| 欧美日韩精品高清| 久久久水蜜桃| 欧美性猛交xxxx免费看久久久| 久久蜜桃资源一区二区老牛| 欧美精品亚洲| 牛人盗摄一区二区三区视频| 欧美先锋影音| 亚洲黄色成人网| 狠狠色伊人亚洲综合成人| 日韩系列欧美系列| 亚洲国产日韩欧美| 欧美在线免费视屏| 亚洲一级高清| 欧美精品国产精品| 麻豆成人91精品二区三区| 国产精品入口| 9l视频自拍蝌蚪9l视频成人| 在线免费观看一区二区三区| 亚洲欧美怡红院| 亚洲一区免费网站| 欧美日本不卡视频| 亚洲国产成人久久综合| 极品av少妇一区二区| 欧美一区二区三区视频在线观看| 亚洲一级网站| 欧美亚洲成人精品| 亚洲精品一区二区在线| 亚洲日本欧美| 欧美国产高清| 亚洲国产精品一区二区www在线| 狠狠色噜噜狠狠色综合久| 欧美一区1区三区3区公司| 午夜亚洲福利在线老司机| 欧美手机在线视频| 一区二区免费看| 亚洲视频精选| 欧美日韩一区三区四区| 日韩亚洲欧美高清| 亚洲一区在线观看视频 | 欧美极品在线观看| 亚洲高清久久| 亚洲免费观看视频| 欧美精品亚洲精品| 99re6热只有精品免费观看| 亚洲视频碰碰| 国产精品久久精品日日| 亚洲欧美日韩国产成人| 欧美一区永久视频免费观看| 国产欧美日韩不卡免费| 欧美影院成年免费版| 久久综合九色欧美综合狠狠| 在线观看不卡av| 美女露胸一区二区三区| 91久久线看在观草草青青| 在线综合视频| 国产精品尤物| 久久久久久亚洲精品中文字幕| 蜜桃久久精品一区二区| 亚洲精品少妇30p| 欧美日韩一区二区在线视频| 亚洲在线观看视频| 久久字幕精品一区| 99精品国产福利在线观看免费| 欧美日韩专区| 欧美在线影院在线视频| 亚洲国产精品久久91精品| 亚洲视频专区在线| 国内精品久久久久久影视8| 欧美成人精品一区二区| 中日韩男男gay无套| 麻豆av一区二区三区| 一本久道综合久久精品| 国产视频一区二区三区在线观看| 噜噜噜噜噜久久久久久91 | 亚洲免费福利视频| 欧美在线视频观看| 亚洲国产欧美精品| 国产精品婷婷午夜在线观看| 美日韩丰满少妇在线观看| 国产精品99久久久久久宅男 | 久久se精品一区二区| 亚洲国产欧洲综合997久久| 国产精品家教| 久久综合中文字幕| 亚洲欧美精品| 日韩视频免费| 欧美成人中文字幕| 久久精品视频99| 亚洲一二区在线| 亚洲国产精品t66y| 国产日韩欧美在线播放不卡| 欧美高清在线| 久久一区中文字幕| 午夜精品久久久久久久99樱桃| 亚洲人成人99网站| 欧美国产日韩视频| 久久久一区二区| 欧美一二三区在线观看| 一区二区三区四区五区视频| 亚洲激情国产| 亚洲国产日韩美| 亚洲高清影视| 一区二区三区在线观看国产| 国产女主播视频一区二区| 欧美日韩一区综合| 欧美激情一区二区三区在线视频观看| 久久精品免费电影| 销魂美女一区二区三区视频在线| 一区二区三区你懂的| 一本色道久久综合狠狠躁篇的优点 | 欧美一级二区| 亚洲一二区在线| 亚洲一级在线| 亚洲欧美日韩精品久久久久| 亚洲性色视频| 亚洲一区二区三区精品视频| 一区二区三区高清在线观看| 一区二区三区久久| 一区二区三区日韩欧美精品| 亚洲深夜福利在线| 亚洲一区二区三区影院| 午夜精品久久久久久久久久久久 | 中文精品一区二区三区| 亚洲私人影院| 亚洲欧洲99久久| 午夜欧美理论片| 欧美资源在线| 久久久免费精品视频| 麻豆免费精品视频| 亚洲第一中文字幕在线观看| 亚洲黄色小视频| 99精品福利视频| 在线中文字幕一区| 午夜日韩激情| 免费观看日韩| 欧美日韩小视频| 国产欧美日韩不卡免费| 在线高清一区| 中国亚洲黄色| 欧美在线关看| 欧美凹凸一区二区三区视频| 亚洲第一区在线观看| 国产精品99久久久久久久vr| 欧美亚洲免费在线| 欧美aⅴ一区二区三区视频| 欧美色精品天天在线观看视频| 国产精品五月天| 亚洲国产三级在线| 亚洲制服av| 猫咪成人在线观看| 在线亚洲+欧美+日本专区| 欧美资源在线| 欧美日韩妖精视频| 韩国三级电影一区二区| 亚洲免费观看在线观看| 久久精品最新地址| 亚洲欧洲日本国产| 久久精品一二三| 国产精品va在线| 在线观看精品一区| 亚洲欧美中日韩| 亚洲国产三级| 久久狠狠婷婷| 国产精品久久久一区麻豆最新章节| 在线播放日韩| 久久超碰97中文字幕| 日韩一区二区精品在线观看| 久久久久国产一区二区三区四区| 欧美性淫爽ww久久久久无| 91久久国产综合久久91精品网站| 久久本道综合色狠狠五月| 99国产精品自拍|