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

asm, c, c++ are my all
-- Core In Computer
posts - 139,  comments - 123,  trackbacks - 0

/********************************************\
|????歡迎轉(zhuǎn)載, 但請保留作者姓名和原文鏈接, 祝您進(jìn)步并共勉!???? |
\********************************************/


1.2 A Keyword Distinction

作者: Jerry Cat
時(shí)間: 2006/04/20
鏈接: http://www.shnenglu.com/jerysun0818/archive/2006/04/22/6064.html

-------------------------
unequivocal: 毫不含糊的
pedestrian:? 步行者; 步行的, 呆板的, 通俗的
infamous:??? 聲名狼藉的
strike aside:閃躲開
brandish:??? 揮舞(n. & v.)
fledgling:?? n.羽毛初長的雛鳥, 羽翼未豐無經(jīng)驗(yàn)的人, 初出茅廬的人
underpinning:基礎(chǔ), 支柱, 支撐
discourse:?? 談話, 演說, 演講, 論文(n. & v.)

C++的struct 與 class有惱人的曖昧關(guān)系, 表面上struct里沒顯式說明存儲權(quán)限的全是public而class則全是private, 事實(shí)卻并非如此簡單當(dāng)考慮到與C的兼容時(shí), 尤其是對待C中的tricks時(shí), 更是traps多多, 地雷密布!

A C program's trick is sometimes a C++ program's trap. One example of this is the use of a one-element array at the end of a struct to allow individual struct objects to address variable-sized arrays:

struct mumble {
?? /* stuff */
?? char pc[ 1 ];
};

// grab a string from file or standard input
// allocate memory both for struct & string

struct mumble *pmumb1 = ( struct mumble* )
?? malloc(sizeof(struct mumble)+strlen(string)+1);//在C中內(nèi)存連續(xù)分布的, 但若考慮到
?? //這是在C++中, struct基本上就是類, 這類的數(shù)據(jù)成員與外來(參)變量的"tricky 捆綁式"
?? //內(nèi)存布局將導(dǎo)致派生類的數(shù)據(jù)成員"插不進(jìn)去"從而導(dǎo)致類的數(shù)據(jù)成員內(nèi)存布局不連續(xù)!
?? //所以C的trick是非標(biāo)準(zhǔn)的不能濫用!

strcpy( &mumble.pc, string );
This may or may not translate well when placed within a class declaration that

1). specifies multiple access sections containing data,
2). derives from another class or is itself the object of derivation, or
3). defines one or more virtual functions.

The data members within a single access section are guaranteed within C++ to be laid out in the order of their declaration. The layout of data contained in multiple access sections, however, is left undefined. In the following declaration, for example, the C trick may or may not work, depending on whether the protected data members are placed before or after those declared private:

class stumble {
public:
?? // operations ...
protected:
?? // protected stuff
private:
?? /* private stuff */
?? char pc[ 1 ];
};
?
Similarly, the layout of data members of the base and derived classes is left undefined, thereby also negating any guarantee that the trick might work. The presence of a virtual function also places the trick's viability in question. The best advice is not to do it. (Chapter 3 discusses these layout issues in greater detail.)

//接上
If a programmer absolutely needs a data portion of an arbitrarily complex C++ class to have the look and feel of an equivalent C declaration, that portion is best factored out into an independent struct declaration. The original idiom for combining this C portion with its C++ part (see [KOENIG93]) was to derive the C++ part from the C struct:

struct C_point { ... };
class Point : public C_point { ... };
thus supporting both the C and C++ usage:

extern void draw_line( Point, Point );
extern "C" void draw_rect ( C_point, C_Point );

draw_line( Point( 0, 0 ), Point( 100, 100 ));
draw_rect( Point( 0, 0 ), Point( 100, 100 ));
This idiom is no longer recommended, however, because of changes to the class inheritance layout in some compilers (for example, the Microsoft C++ compiler) in support of the virtual function mechanism (see Section 3.4 for a discussion). Composition, rather than inheritance, is the only portable method of combining C and C++ portions of a class (the conversion operator provides a handy extraction method):

struct C_point { ... };

class Point {
public:
?? operator C_point() { return _c_point; }
?? // ...
private:
?? C_point _c_point;
?? // ...
};

強(qiáng)烈不推薦這種種"淫巧",? 不過在C/C++混合編程時(shí)你還不得不用它:)
One reasonable use of the C struct in C++, then, is when you want to pass all or part of a complex class object to a C function. This struct declaration serves to encapsulate that data and guarantees a compatible C storage layout. This guarantee, however, is maintained only under composition. Under inheritance, the compiler decides whether additional data members are inserted within the base struct subobject (again, see Section 3.4 for a discussion, as well as Figures 3.2(a) and 3.2(b)).

posted on 2006-04-22 01:23 Jerry Cat 閱讀(670) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理



<2006年4月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿(7)

隨筆檔案

最新隨筆

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 欧美大片一区二区| 亚洲特黄一级片| 亚洲永久免费av| 国产一区二区三区自拍| 女生裸体视频一区二区三区| 欧美国产精品v| 亚洲一级电影| 久久久久九九九| 99视频一区| 亚洲欧美久久| 亚洲人体1000| 亚洲一区二区在线免费观看视频| 国内精品久久久久久久影视麻豆 | 久久婷婷丁香| 欧美v国产在线一区二区三区| 一本色道久久综合狠狠躁篇怎么玩| 中文一区二区| 伊人色综合久久天天| 亚洲精华国产欧美| 国产日韩欧美黄色| 亚洲国产精品一区| 国产日产精品一区二区三区四区的观看方式 | 中文亚洲欧美| 永久免费毛片在线播放不卡| 亚洲人成亚洲人成在线观看| 国产精品亚洲片夜色在线| 美日韩在线观看| 欧美亚州一区二区三区| 老妇喷水一区二区三区| 欧美视频专区一二在线观看| 久久综合色8888| 国产精品高清在线| 亚洲电影在线观看| 国产亚洲一级高清| 一区二区三区你懂的| 在线观看亚洲一区| 午夜精品区一区二区三| 在线亚洲观看| 免费观看30秒视频久久| 久久国产欧美日韩精品| 欧美色视频日本高清在线观看| 久久亚洲欧美国产精品乐播| 国产精品嫩草影院av蜜臀| 亚洲国产日韩欧美在线动漫| 国内精品久久久久影院 日本资源| 亚洲乱码国产乱码精品精98午夜 | 精品999网站| 亚洲欧美资源在线| 亚洲在线观看视频网站| 欧美人与性动交cc0o| 欧美高清视频一二三区| 激情成人在线视频| 性色av一区二区三区在线观看 | 国产欧美精品| 亚洲女人天堂成人av在线| 亚洲一区二区三区在线看| 欧美激情中文字幕一区二区| 欧美电影在线免费观看网站| 狠狠色香婷婷久久亚洲精品| 先锋影音久久久| 小嫩嫩精品导航| 国产欧美一区二区精品仙草咪| 一区二区三区你懂的| 在线视频一区观看| 欧美日韩在线免费观看| 亚洲美女一区| 亚洲一区二区三区高清 | 欧美精品午夜视频| 亚洲精品欧洲| 亚洲午夜激情网站| 国产精品久99| 欧美一区二区三区四区在线观看地址 | 亚洲一区二区不卡免费| 国产精品xnxxcom| 亚洲欧美日韩国产一区二区三区 | 麻豆精品一区二区综合av| 一区二区三区在线免费视频| 久久午夜国产精品| 亚洲高清自拍| 亚洲综合色视频| 国产欧美日韩中文字幕在线| 久久精品一级爱片| 欧美激情一区二区久久久| 日韩视频一区二区三区在线播放| 欧美日韩亚洲一区二| 亚洲一区二区三区在线| 久久偷窥视频| 99日韩精品| 国产亚洲午夜| 欧美精品三区| 久久精品国产久精国产思思| 亚洲福利国产| 欧美在线关看| 亚洲精品影视| 国产一区自拍视频| 欧美激情一区在线观看| 亚洲欧美一区二区精品久久久| 美女网站久久| 午夜久久久久久久久久一区二区| 黑人巨大精品欧美一区二区| 欧美精品一区二区精品网| 亚洲欧美国产77777| 亚洲激情av| 久久久亚洲综合| 一本到高清视频免费精品| 国产字幕视频一区二区| 欧美视频成人| 免费成人高清视频| 性色av一区二区三区在线观看| 亚洲国产一区二区在线| 久久精品噜噜噜成人av农村| 中日韩高清电影网| 亚洲国产一区二区三区在线播| 国产欧美日韩综合精品二区| 欧美激情成人在线| 久久天堂国产精品| 欧美一级理论片| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美激情一区二区三区在线视频观看 | 一本色道久久综合亚洲精品婷婷 | 久久成人资源| 亚洲一区二区三区国产| 亚洲高清免费在线| 久久综合网色—综合色88| 午夜在线电影亚洲一区| 亚洲少妇中出一区| 99re66热这里只有精品3直播| 在线观看欧美视频| 国内精品视频在线播放| 国产欧美日韩不卡| 国产精品一区免费视频| 欧美性猛交一区二区三区精品| 欧美成人午夜激情| 免费成人你懂的| 欧美11—12娇小xxxx| 老司机精品视频网站| 久久婷婷激情| 久久中文欧美| 蜜臀av国产精品久久久久| 老司机精品视频网站| 裸体丰满少妇做受久久99精品| 久久久久久久一区二区三区| 久久精品国产精品亚洲综合| 久久激情一区| 久久资源av| 欧美激情小视频| 欧美深夜福利| 国产毛片精品国产一区二区三区| 国产农村妇女毛片精品久久莱园子| 国产精品亚洲成人| 国内综合精品午夜久久资源| 伊人蜜桃色噜噜激情综合| 亚洲缚视频在线观看| 亚洲毛片一区| 亚洲欧美中文另类| 欧美专区在线观看| 欧美 日韩 国产在线| 亚洲国产精品一区二区第一页| 亚洲理伦在线| 先锋影音久久久| 美女视频一区免费观看| 欧美久色视频| 国产视频精品va久久久久久| 在线免费观看视频一区| 日韩视频免费观看高清完整版| 亚洲一区二区三区777| 久久精品电影| 亚洲国产精品久久久久婷婷老年| 99国产精品私拍| 性伦欧美刺激片在线观看| 久久漫画官网| 国产精品sss| 亚洲成色www8888| 亚洲综合激情| 欧美激情日韩| 羞羞答答国产精品www一本| 蜜臀av一级做a爰片久久| 国产精品白丝jk黑袜喷水| 伊人久久成人| 亚洲女人天堂av| 亚洲成人直播| 一本色道久久综合亚洲精品按摩 | 亚洲人体1000| 欧美一级视频免费在线观看| 欧美国产日韩一区二区在线观看| 日韩午夜av在线| 久久精品视频在线| 国产精品高潮呻吟久久| 亚洲第一福利视频| 欧美一区二区精品| 亚洲精品少妇30p| 久久久久久国产精品mv| 欧美日韩在线一区| 亚洲国产毛片完整版|