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

Cpper
C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
摘要:本文主要討論如何書寫權(quán)威的庫頭文件-c or cplusplus.
如何書寫權(quán)威的頭文件?
這是個問題
如果看得代碼多了,經(jīng)驗多了是不是可以得出權(quán)威的頭文件應(yīng)該滿足這個樣子?
1.必要的版權(quán)格式或者文檔說明
2.作者,日期,地點,版本等信息
3.如果有必要盡可能不要使用中文,這些寫出來的文件看上去很牛逼
4.關(guān)于注釋:使用統(tǒng)一的注釋風(fēng)格 這樣弄出來的文件看上去很有美感
5.盡可能使用統(tǒng)一的文件編輯器,免得影響在其他編輯器出來的效果
6.使用宏防止重復(fù)包含頭文件
    比如 #ifndef ..
7.考慮庫是不是平臺相關(guān)的
如果必要加上判斷平臺的宏 這樣讀者會感覺專業(yè)很多    
8.如果必要重新定義基本類型
比如typedef unsigned int uint.----為了打造權(quán)威 我們一定要這樣做
9.為了進一步鞏固我們的權(quán)威形象-我們可以根據(jù)平臺加入需要的頭文件
比如:
#if defined(__FreeBSD__) && (__FreeBSD__ >= 2)
/* Needed for __FreeBSD_version symbol definition */

#else

#endif
10.盡可能的多使用宏
比如一般情況下TRUE都是定義過的
為了體現(xiàn)庫的權(quán)威性 我們這樣弄
#ifndef TRUE
#define TRUE 1
#endif
11.如果是c接口的庫
頭文件還需要加上
#ifdef  __cplusplus
extern "C" {
#endif
12.對于命名格式 在保持統(tǒng)一的情況下我們最好不采用一般的命名格式
不要使用通用的setValue也不采用SetValue或者set_value
那如何寫呢?
可以這樣
XX_setValue 在這里XX代表庫的縮寫
比如Python 就是Py
專家就是要和別人不一樣
13.如果是cplusplus庫接口,那么庫的頭文件中盡可能的使用抽象基類,甚至使用虛析構(gòu)函數(shù)。
如果需要或者對象指針我們可以增加一個接口比如GetObject
14.頭文件盡可能的不要包含不相關(guān)的內(nèi)容-原則讓用戶知道她想知道的隱藏她不需要的
15.對于句柄類的我們一定要使用pimpl技法
比如lua中的lua_State句柄就是typedef struct lua_State lua_State;
16.如果需要命名空間,一般情況下我們會這樣比如:
namespace core
{
..
}
考慮到第10個原則這樣弄吧
還是使用宏
#define BEGIN_CORE_NAMESPACE namespace {
#define END_CORE_NAMGESPACE }
比如QT中就是這樣弄得
BEGIN_QT_NAMESPACE
     
class QLabel;
     
class QSpinBox;
     
class QSlider;
     
class QAction;
END_QT_NAMESPACE 
freetype中類似的是FT_BEGIN_HEADER
17.如果需要導(dǎo)出鏈接
如果這樣寫只能說明你是初級水準(zhǔn)
GAPI void G_CALL gTerminate();
那如何寫你?
做法就是再定義一個后
比如
#define G_EXPORT(para) GAPI para G_CALL
然后這樣使用
G_EXPORT(void) gTerminate();
如果這樣弄不想權(quán)威也不行
18.總結(jié):
權(quán)威就是要讓別人不能置否,要讓讀者知道這樣就是對的。

PS:如果堅持這樣,過不了多久,你肯定就是權(quán)威
附注:雖然一切都是神馬



posted on 2011-03-17 16:39 ccsdu2009 閱讀(2413) 評論(11)  編輯 收藏 引用 所屬分類: 軟件工程
Comments
  • # re: 如何書寫權(quán)威的程序庫頭文件
    Kevin Lynx
    Posted @ 2011-03-17 18:11
    - -| 別人那樣寫是有原因的。尤其是跨平臺代碼(導(dǎo)致各種宏)、開源代碼(導(dǎo)致各種版權(quán)注釋)、避免名字沖突的庫代碼(導(dǎo)致符號前綴)。。。  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    ccsdu2009
    Posted @ 2011-03-17 18:26
    @Kevin Lynx
    我這樣寫也有原因 呵呵  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    linux23
    Posted @ 2011-03-18 00:17
    只能說明你還處于一個很膚淺的總是沾沾自喜秀代碼的階段  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    zuhd
    Posted @ 2011-03-18 09:27
    #define BEGIN_CORE_NAMESPACE namespace {
    #define END_CORE_NAMGESPACE }

    對于這樣的宏 我實在是不敢茍同啊 和宏的初衷有點背離不是嗎?
    至少閱讀代碼時我要跟蹤下definition 裝B成分太多  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    溪流
    Posted @ 2011-03-18 09:29
    哈哈  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    pass by
    Posted @ 2011-03-18 09:52
    如果必要重新定義基本類型
    比如typedef unsigned int uint.----為了打造權(quán)威 我們一定要這樣做

    自己的代碼,實在是不想搞這么復(fù)雜,我說真的  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    ccsdu2009
    Posted @ 2011-03-18 11:10
    @linux23
    呵呵  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    zwp
    Posted @ 2011-03-18 12:39
    一半搞笑,一半有用。  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    空明流轉(zhuǎn)
    Posted @ 2011-03-18 14:22
    @zuhd
    這個是為了避免namespace在大多數(shù)IDE的自動格式化中導(dǎo)致縮進。  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    cpp偽專家
    Posted @ 2011-03-18 14:22
    不知道樓主是真膚淺還是說反話。  回復(fù)  更多評論   
  • # re: 如何書寫權(quán)威的程序庫頭文件
    ccsdu2009
    Posted @ 2011-03-18 18:33
    @zwp
    如何覺得搞笑 你可以看看很多c++庫都是如何寫的  回復(fù)  更多評論   

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


 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产午夜精品理论片a级大结局| 欧美精品三级| 久久亚洲精品欧美| 久久免费99精品久久久久久| 久久久99精品免费观看不卡| 久久裸体艺术| 欧美黄色免费| 在线综合亚洲欧美在线视频| 午夜精品一区二区三区四区| 久久高清一区| 欧美人与性动交cc0o| 欧美日韩一区二区在线观看视频 | 美女视频黄免费的久久| 欧美成人a视频| 亚洲最快最全在线视频| 久久国产精品久久久久久电车| 毛片基地黄久久久久久天堂| 欧美日韩成人综合在线一区二区| 国产精品素人视频| 亚洲黄一区二区| 亚洲欧美日韩国产| 欧美黄色一级视频| 亚洲欧美日韩国产成人| 欧美韩日精品| 黄色一区二区三区四区| 亚洲新中文字幕| 欧美刺激性大交免费视频| 中文高清一区| 欧美国产91| 亚洲第一中文字幕在线观看| 性色av一区二区三区红粉影视| 欧美激情精品久久久| 欧美一区二区三区在线观看| 欧美日韩中文字幕| 亚洲国产精品成人va在线观看| 亚洲伊人第一页| 91久久精品一区二区别| 久色婷婷小香蕉久久| 亚洲乱码一区二区| 久久成人av少妇免费| 亚洲作爱视频| 欧美国产日韩亚洲一区| 亚洲第一页自拍| 免费人成精品欧美精品| 欧美在线观看视频在线| 国产美女精品免费电影| 亚洲中字在线| 亚洲午夜久久久久久久久电影网| 免费看av成人| 亚洲成人中文| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲自拍偷拍视频| 国产精品视频专区| 性视频1819p久久| 一区二区三区国产精品| 欧美激情一二三区| 一本到高清视频免费精品| 亚洲黄色天堂| 欧美粗暴jizz性欧美20| 亚洲日本电影| 亚洲精品久久久久久久久久久久| 久久综合精品国产一区二区三区| 在线电影国产精品| 欧美激情精品久久久久| 免费看成人av| 一区二区三区产品免费精品久久75| 亚洲激情网址| 欧美日韩中文字幕在线| 亚洲欧美在线一区| 一区二区三区你懂的| 国产精品制服诱惑| 美国十次成人| 欧美激情四色| 午夜精品影院| 久久不射网站| 亚洲麻豆视频| 亚洲一区二区三区精品视频| 国产女主播一区二区| 久久激情视频久久| 久久久青草青青国产亚洲免观| 亚洲国产精品毛片| 99视频超级精品| 国产精品第一区| 久久亚洲欧美| 欧美日在线观看| 久久综合久久综合久久| 欧美日韩成人| 久久精品中文字幕一区| 美乳少妇欧美精品| 99在线精品免费视频九九视| 亚洲视频网站在线观看| 国产伦精品一区二区三区| 牛牛影视久久网| 国产精品嫩草影院av蜜臀| 欧美高清视频| 国产日韩欧美成人| 亚洲电影免费观看高清| 国产精品久久久久av| 欧美aaaaaaaa牛牛影院| 狠狠狠色丁香婷婷综合激情| 狠狠综合久久| 女女同性精品视频| 国产精品久久9| 欧美成人有码| 国产视频在线观看一区二区三区| 亚洲国产视频一区二区| 国内精品视频在线观看| 99国产精品一区| 亚洲国产专区校园欧美| 亚久久调教视频| 中文久久精品| 欧美aⅴ99久久黑人专区| 欧美大胆人体视频| 伊人夜夜躁av伊人久久| 亚洲免费在线观看| 一本色道久久综合亚洲精品高清| 久久成人免费日本黄色| 亚洲欧美日韩人成在线播放| 欧美粗暴jizz性欧美20| 欧美h视频在线| 国产一区二区三区四区| 亚洲天天影视| 亚洲男人的天堂在线观看| 欧美日韩国产小视频在线观看| 免费久久99精品国产| 国产综合在线看| 欧美一区二区三区视频| 欧美中日韩免费视频| 国产精品一级在线| 亚洲一级网站| 亚洲欧美日韩久久精品| 欧美系列一区| 亚洲一区视频在线| 午夜日韩在线| 国产区精品在线观看| 午夜精品成人在线视频| 久久gogo国模裸体人体| 国产伦精品一区二区三区免费迷 | 亚洲综合精品一区二区| 欧美精品久久久久久久免费观看| 欧美激情 亚洲a∨综合| 最新国产成人在线观看| 欧美aa国产视频| 亚洲欧洲在线播放| 亚洲天堂成人在线观看| 国产精品久久999| 亚洲欧美日韩综合国产aⅴ| 欧美在线啊v| 在线观看精品| 欧美激情视频网站| 亚洲男人的天堂在线| 久久九九热re6这里有精品| 精东粉嫩av免费一区二区三区| 久久夜色精品国产欧美乱| 亚洲国产日韩一区| 中文国产成人精品久久一| 国产老女人精品毛片久久| 久久激情婷婷| 亚洲国产精品福利| 午夜欧美大尺度福利影院在线看| 国内精品久久久| 欧美精品在线观看播放| 亚洲女爱视频在线| 欧美大片免费久久精品三p | 亚洲图片欧洲图片日韩av| 国产精品久久国产三级国电话系列| 亚洲一区二区精品视频| 鲁大师成人一区二区三区| aⅴ色国产欧美| 国产亚洲精品高潮| 欧美精品在线视频观看| 亚洲一区二区在线视频| 欧美成人黑人xx视频免费观看| 一区二区毛片| 樱花yy私人影院亚洲| 欧美日韩免费一区二区三区| 久久精品1区| 一区二区三欧美| 欧美国产激情二区三区| 欧美一级久久久久久久大片| 亚洲精品在线电影| 国产又爽又黄的激情精品视频 | 久久免费视频这里只有精品| 夜夜夜久久久| 欧美激情无毛| 久久五月激情| 欧美一区国产在线| 在线综合亚洲| 亚洲精美视频| 在线观看欧美激情| 国产亚洲精品aa| 国产精品电影在线观看| 欧美xxxx在线观看| 久久亚洲精品一区二区| 亚洲欧美偷拍卡通变态| 中文网丁香综合网| 一区二区三区久久网| 亚洲电影在线| 蜜臀a∨国产成人精品| 久久久久久久激情视频|