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

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>
            亚洲欧美日韩国产| 美女主播一区| 国产日韩精品视频一区| 欧美一区二区三区免费看| 制服丝袜激情欧洲亚洲| 国产精品欧美日韩| 欧美在线播放一区二区| 欧美在线视频一区| 在线国产欧美| 亚洲精品久久7777| 国产精品高精视频免费| 久久漫画官网| 欧美福利视频一区| 午夜在线视频观看日韩17c| 午夜精品一区二区在线观看| 激情久久久久久久久久久久久久久久| 免费观看日韩| 国产精品av一区二区| 久久久777| 欧美日韩高清在线观看| 久久狠狠久久综合桃花| 久久这里只精品最新地址| 国产精品99久久久久久久vr| 亚洲欧美日韩成人| 亚洲美女在线国产| 欧美一级久久久| 一本一本久久a久久精品牛牛影视| 国产精品99久久久久久久女警 | 影音先锋一区| 日韩亚洲一区在线播放| 狠狠色狠狠色综合人人| 亚洲最新视频在线播放| 在线看日韩av| 午夜精品一区二区三区四区| 亚洲美女av网站| 午夜欧美精品久久久久久久| 日韩视频在线一区| 久久国产精品色婷婷| 中国女人久久久| 久久中文久久字幕| 久久激情久久| 欧美特黄一级大片| 91久久精品日日躁夜夜躁国产| 国产日韩欧美一区二区三区四区| 亚洲激情一区| 亚洲高清av在线| 欧美在线影院在线视频| 欧美一级片在线播放| 欧美欧美午夜aⅴ在线观看| 蜜臀99久久精品久久久久久软件| 国产欧美视频一区二区| 99视频精品| 亚洲视频在线观看| 欧美国产激情| 亚洲高清av| 亚洲日韩成人| 久久久久久97三级| 久久国产精品免费一区| 国产嫩草影院久久久久| 一区二区av在线| 亚洲一区二区三区四区五区午夜| 欧美精品自拍| 亚洲人成亚洲人成在线观看图片 | 欧美午夜电影网| 亚洲美女黄网| 一区二区三区精品久久久| 欧美成人第一页| 亚洲黄色在线观看| 亚洲精品色婷婷福利天堂| 欧美第一黄网免费网站| 亚洲国内精品在线| av成人动漫| 欧美三级中文字幕在线观看| 日韩视频三区| 亚洲欧美视频在线观看视频| 国产精品网站一区| 欧美在线观看日本一区| 久久久免费精品| 伊人一区二区三区久久精品| 久久久视频精品| 亚洲盗摄视频| 在线亚洲精品| 亚洲女同性videos| 日韩午夜在线观看视频| 欧美激情中文不卡| 亚洲看片免费| 午夜精品亚洲一区二区三区嫩草| 国产欧美在线视频| 久久女同互慰一区二区三区| 亚洲国产精选| 亚洲影音先锋| 国内成人精品一区| 欧美激情精品久久久久久蜜臀| 亚洲精选在线观看| 久久精品久久综合| 亚洲国产天堂久久综合| 欧美天堂亚洲电影院在线观看 | 久久婷婷丁香| 亚洲精品久久久蜜桃| 国产精品伦一区| 久久综合狠狠综合久久综青草| 91久久精品一区二区三区| 亚洲欧洲99久久| 亚洲激情av在线| 国产精品亚洲视频| 欧美+日本+国产+在线a∨观看| 一区二区日韩欧美| 免费看的黄色欧美网站| 亚洲一区二区在线| 亚洲夫妻自拍| 国产日韩精品在线观看| 欧美精品导航| 久久精品国产96久久久香蕉| 一区二区三区**美女毛片| 久久综合福利| 久久av二区| 中日韩视频在线观看| 在线播放豆国产99亚洲| 国产精品国色综合久久| 欧美.com| 快播亚洲色图| 欧美主播一区二区三区美女 久久精品人| 亚洲韩国青草视频| 美女久久网站| 久久影院午夜论| 欧美专区福利在线| 亚洲一区二区在线观看视频| 日韩亚洲在线| 亚洲激情第一区| 激情久久久久久久| 国产在线观看一区| 国产精品综合久久久| 国产精品久99| 欧美日韩在线亚洲一区蜜芽| 欧美肥婆bbw| 麻豆久久精品| 奶水喷射视频一区| 老司机午夜免费精品视频| 久久精品综合网| 久久久久免费视频| 久久国产精品电影| 久久久久久国产精品一区| 欧美在线观看视频一区二区三区| 午夜国产欧美理论在线播放| 亚洲视频在线观看三级| 宅男精品视频| 亚洲欧美韩国| 久久精品国产一区二区电影| 小处雏高清一区二区三区| 欧美在线播放一区二区| 久久国产精彩视频| 老司机午夜精品视频在线观看| 久热综合在线亚洲精品| 欧美成人免费视频| 欧美精品一区二区三区视频| 欧美日韩高清不卡| 国产精品久久久久一区二区三区共| 欧美性猛交一区二区三区精品| 欧美视频免费在线| 国产日韩欧美不卡在线| 伊人精品视频| 亚洲精品一区二区三区蜜桃久| 一区二区三区免费网站| 午夜视频一区在线观看| 久热精品视频在线观看| 亚洲第一区在线| 欧美日韩国产精品自在自线| 亚洲人成欧美中文字幕| 亚洲片区在线| 午夜精品久久久久影视| 欧美亚洲视频一区二区| 久久嫩草精品久久久精品| 男女激情视频一区| 国产精品久久久久99| 黄色成人小视频| 洋洋av久久久久久久一区| 午夜精品久久久久久久99樱桃| 久久精品欧美日韩精品| 亚洲片国产一区一级在线观看| 亚洲视频自拍偷拍| 久久婷婷国产综合国色天香| 欧美日韩国产高清| 国产丝袜一区二区| 一本大道久久精品懂色aⅴ| 欧美一区二区在线播放| 亚洲高清久久网| 午夜一区不卡| 欧美日韩免费一区| 亚洲国产99| 性8sex亚洲区入口| 亚洲人成毛片在线播放| 欧美中文字幕在线| 欧美亚一区二区| 亚洲韩国精品一区| 久久成人免费视频| 一本久久精品一区二区| 欧美成人精品1314www| 国产一区二区三区四区在线观看| 妖精成人www高清在线观看| 欧美成人日韩|