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

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>
            亚洲国产精品一区二区www在线| 久久爱www久久做| 亚洲综合国产| 国产婷婷色一区二区三区| 久久福利视频导航| 欧美激情在线观看| 亚洲专区一区| 激情偷拍久久| 欧美精品一区二区三区很污很色的 | 亚洲手机成人高清视频| 国产精品爽爽ⅴa在线观看| 欧美中文在线免费| 亚洲国产一区二区a毛片| 亚洲视频播放| 尤物九九久久国产精品的特点| 欧美fxxxxxx另类| 亚洲在线网站| 欧美国产亚洲另类动漫| 亚洲欧美日韩国产中文| 在线观看一区欧美| 国产精品二区在线观看| 久热精品在线| 亚洲自拍偷拍麻豆| 亚洲高清在线精品| 久久久国产视频91| 99热精品在线观看| 国产一区二区中文字幕免费看| 欧美v日韩v国产v| 亚洲综合色视频| 亚洲全部视频| 鲁大师成人一区二区三区| 亚洲婷婷免费| 亚洲啪啪91| 国内一区二区三区在线视频| 欧美日韩理论| 欧美v日韩v国产v| 欧美在线免费| 亚洲无线一线二线三线区别av| 欧美国产高清| 久久免费视频这里只有精品| 亚洲欧美日韩国产成人精品影院 | 久久国产欧美日韩精品| 99国产精品国产精品毛片| 国内精品一区二区三区| 国产精品vip| 欧美久久在线| 免费成人av在线| 久久久综合免费视频| 午夜精品一区二区在线观看| 日韩视频永久免费| 亚洲激情成人在线| 欧美激情久久久| 老色批av在线精品| 久久国产直播| 久久激情五月激情| 欧美亚洲一级片| 香蕉久久夜色| 午夜一级久久| 欧美一级片一区| 午夜精品久久久久久久久| 亚洲视频欧美视频| 一区二区三区蜜桃网| 日韩特黄影片| aa成人免费视频| 99精品欧美一区二区三区综合在线| 亚洲国产欧美日韩| 亚洲狠狠丁香婷婷综合久久久| 亚洲成色777777女色窝| 狠狠狠色丁香婷婷综合激情| 狠狠色丁香久久婷婷综合丁香| 国产色综合久久| 国产一区二区三区视频在线观看| 国产亚洲精品久久久久久| 国产资源精品在线观看| 国产一区二区三区视频在线观看 | 欧美—级高清免费播放| 欧美岛国在线观看| 欧美巨乳在线观看| 国产精品av免费在线观看| 国产精品美女视频网站| 国产欧美日韩一区二区三区在线观看 | 久久免费视频在线观看| 免费日韩视频| 欧美激情网友自拍| 亚洲人成网站影音先锋播放| 日韩亚洲欧美综合| 亚洲一区二区三区免费观看| 欧美亚洲视频一区二区| 久久综合九色综合欧美就去吻| 欧美成人精品1314www| 欧美日韩亚洲一区二区三区在线观看 | 久久久久国色av免费看影院| 久久综合伊人77777蜜臀| 欧美韩日一区二区| 欧美性大战久久久久| 国产亚洲第一区| 亚洲黄色三级| 亚洲永久视频| 免费成人黄色| 亚洲免费精彩视频| 久久av在线看| 欧美日韩91| 国产最新精品精品你懂的| 91久久综合| 欧美一区二区私人影院日本| 免费成人在线观看视频| 亚洲伦理在线观看| 欧美在线播放高清精品| 欧美日韩高清在线观看| 国产亚洲va综合人人澡精品| 日韩网站在线| 久久久久久久尹人综合网亚洲| 亚洲精品日产精品乱码不卡| 午夜在线视频观看日韩17c| 欧美国产日韩一二三区| 国产三区二区一区久久 | 亚洲视频在线播放| 久久久综合精品| 日韩一级黄色大片| 久久亚洲私人国产精品va媚药| 国产精品毛片a∨一区二区三区| **网站欧美大片在线观看| 亚洲欧美自拍偷拍| 亚洲国产精品ⅴa在线观看 | 欧美国产日韩一区二区三区| 亚洲一区二区三区在线看| 欧美成人综合网站| 一区二区三区无毛| 香蕉久久夜色| av成人天堂| 欧美福利网址| 亚洲国产导航| 久久精品最新地址| 一区二区高清视频在线观看| 男男成人高潮片免费网站| 国产日韩一区欧美| 亚洲欧美日韩直播| 亚洲精品久久久久| 欧美α欧美αv大片| 在线观看欧美成人| 久久色中文字幕| 午夜精品久久久久久久久久久久久| 欧美日韩精品一区视频| 亚洲精品老司机| 欧美国产另类| 久久影视精品| 曰本成人黄色| 女女同性精品视频| 欧美专区亚洲专区| 国产伦精品一区二区三区高清版 | 亚洲人www| 欧美二区在线看| 亚洲日本成人女熟在线观看| 欧美不卡视频| 裸体丰满少妇做受久久99精品| 黄色在线成人| 欧美成熟视频| 美女精品国产| 日韩视频免费看| 亚洲精品免费观看| 欧美日韩一区二区精品| 亚洲一区二区视频| 一本色道久久综合精品竹菊 | 韩国成人福利片在线播放| 欧美专区在线播放| 午夜日韩激情| 国内精品久久久久久久影视麻豆| 久久欧美肥婆一二区| 久久久女女女女999久久| **网站欧美大片在线观看| 免费观看在线综合色| 美女精品一区| 在线视频亚洲欧美| 中文在线一区| 国产一区二区高清不卡| 久久资源av| 欧美多人爱爱视频网站| 99精品福利视频| 亚洲影音一区| 永久免费毛片在线播放不卡| 亚洲国产裸拍裸体视频在线观看乱了| 欧美精品亚洲一区二区在线播放| 亚洲午夜视频在线| 欧美一级黄色网| 亚洲日本成人在线观看| 99ri日韩精品视频| 国产欧美日韩另类一区| 欧美成人性网| 欧美日韩网站| 久久人人爽人人爽爽久久| 欧美暴力喷水在线| 亚洲制服av| 久久天堂成人| 亚洲性色视频| 久久久久国产精品一区二区| 宅男在线国产精品| 久久成人精品无人区| 99re在线精品| 欧美在线视频免费观看| 亚洲精选大片|