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

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

#else

#endif
10.盡可能的多使用宏
比如一般情況下TRUE都是定義過的
為了體現庫的權威性 我們這樣弄
#ifndef TRUE
#define TRUE 1
#endif
11.如果是c接口的庫
頭文件還需要加上
#ifdef  __cplusplus
extern "C" {
#endif
12.對于命名格式 在保持統一的情況下我們最好不采用一般的命名格式
不要使用通用的setValue也不采用SetValue或者set_value
那如何寫呢?
可以這樣
XX_setValue 在這里XX代表庫的縮寫
比如Python 就是Py
專家就是要和別人不一樣
13.如果是cplusplus庫接口,那么庫的頭文件中盡可能的使用抽象基類,甚至使用虛析構函數。
如果需要或者對象指針我們可以增加一個接口比如GetObject
14.頭文件盡可能的不要包含不相關的內容-原則讓用戶知道她想知道的隱藏她不需要的
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.如果需要導出鏈接
如果這樣寫只能說明你是初級水準
GAPI void G_CALL gTerminate();
那如何寫你?
做法就是再定義一個后
比如
#define G_EXPORT(para) GAPI para G_CALL
然后這樣使用
G_EXPORT(void) gTerminate();
如果這樣弄不想權威也不行
18.總結:
權威就是要讓別人不能置否,要讓讀者知道這樣就是對的。

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



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

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

    自己的代碼,實在是不想搞這么復雜,我說真的  回復  更多評論   
  • # re: 如何書寫權威的程序庫頭文件
    ccsdu2009
    Posted @ 2011-03-18 11:10
    @linux23
    呵呵  回復  更多評論   
  • # re: 如何書寫權威的程序庫頭文件
    zwp
    Posted @ 2011-03-18 12:39
    一半搞笑,一半有用。  回復  更多評論   
  • # re: 如何書寫權威的程序庫頭文件
    空明流轉
    Posted @ 2011-03-18 14:22
    @zuhd
    這個是為了避免namespace在大多數IDE的自動格式化中導致縮進。  回復  更多評論   
  • # re: 如何書寫權威的程序庫頭文件
    cpp偽專家
    Posted @ 2011-03-18 14:22
    不知道樓主是真膚淺還是說反話。  回復  更多評論   
  • # re: 如何書寫權威的程序庫頭文件
    ccsdu2009
    Posted @ 2011-03-18 18:33
    @zwp
    如何覺得搞笑 你可以看看很多c++庫都是如何寫的  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费在线看成人av| 午夜精品久久久久久久99热浪潮| 久久综合九色九九| 久久综合国产精品| 亚洲麻豆av| 亚洲一区二区三区乱码aⅴ| 国产女人aaa级久久久级| 久久一区二区三区国产精品| 老司机aⅴ在线精品导航| 99视频精品免费观看| 在线亚洲国产精品网站| 国内精品久久久久影院色| 欧美福利视频在线观看| 欧美性大战久久久久| 久久久久久网| 欧美肥婆在线| 久久精品一区四区| 欧美电影免费观看高清| 欧美一区二区成人| 国产精品成人播放| 亚洲福利视频免费观看| 欧美国产视频在线| 欧美一区2区三区4区公司二百| 久久综合九色九九| 亚洲欧美日韩天堂| 麻豆成人av| 久久精品国产一区二区三区免费看 | 欧美日韩一区在线| 久久免费视频网站| 欧美性一区二区| 亚洲电影观看| 国产一区二区高清| 日韩视频一区二区三区| 亚洲第一主播视频| 午夜综合激情| 亚洲天堂av在线免费| 久久综合色一综合色88| 久久精品女人| 国产精品久久福利| 亚洲人成在线影院| 亚洲二区在线观看| 午夜精品久久久久久久久久久久| 99re6热只有精品免费观看| 久久精品一区二区三区不卡| 性欧美大战久久久久久久久| 欧美日韩123| 亚洲国产精品一区制服丝袜| 精品不卡在线| 欧美中文字幕视频在线观看| 欧美在线一级va免费观看| 欧美三级午夜理伦三级中文幕 | 久久精彩视频| 国产精品实拍| 亚洲午夜黄色| 亚洲欧美久久久久一区二区三区| 欧美交受高潮1| 亚洲国产精品久久久久久女王| 亚洲二区在线| 免费视频一区二区三区在线观看| 久久影视精品| 伊人成人在线视频| 狂野欧美一区| 欧美高清视频| 亚洲精品视频在线| 欧美久久久久久| 夜夜嗨av一区二区三区中文字幕 | 久久综合九色综合久99| 国产在线精品一区二区夜色| 久久久99国产精品免费| 美女网站久久| 亚洲人体一区| 欧美午夜电影一区| 亚洲欧美日本日韩| 久久伊人精品天天| 亚洲人成网站色ww在线| 欧美日韩国产亚洲一区| 亚洲免费一在线| 久久全球大尺度高清视频| 在线日本欧美| 欧美视频网址| 欧美一级免费视频| 乱中年女人伦av一区二区| 日韩亚洲在线| 国产精品久久久久久久一区探花 | 欧美成人首页| 夜色激情一区二区| 国产欧美日韩一区二区三区在线观看| 久久国产成人| 亚洲人精品午夜在线观看| 销魂美女一区二区三区视频在线| 精品91在线| 欧美午夜一区| 久久精品国产精品| 亚洲精品在线免费| 久久精品视频va| 99re热这里只有精品视频| 国产精品影视天天线| 美日韩精品视频| 亚洲你懂的在线视频| 欧美激情一区二区三级高清视频| 亚洲综合999| 91久久久久久| 国产亚洲aⅴaaaaaa毛片| 欧美成人免费网| 欧美一区二区精品久久911| 亚洲精品视频免费| 你懂的国产精品| 欧美一区激情| 亚洲午夜激情| 亚洲精品人人| 一区在线播放视频| 国产欧美一区二区三区另类精品| 欧美va天堂| 久久国产欧美日韩精品| 日韩一级免费观看| 亚洲电影在线| 免费91麻豆精品国产自产在线观看| 亚洲欧美国产高清| 99国内精品久久久久久久软件| 黑人巨大精品欧美一区二区小视频 | 欧美.www| 久久理论片午夜琪琪电影网| 亚洲一区一卡| 亚洲调教视频在线观看| 亚洲另类自拍| 亚洲精品在线观| 91久久极品少妇xxxxⅹ软件| 欧美成黄导航| 美女脱光内衣内裤视频久久影院| 久久久精彩视频| 欧美一级淫片播放口| 亚洲小说春色综合另类电影| 一区二区三欧美| 夜夜精品视频一区二区| 99精品视频免费| 99这里有精品| 一区二区三区精品视频| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美大片免费久久精品三p| 久久一综合视频| 免费日本视频一区| 欧美成人综合在线| 欧美成人按摩| 欧美日韩亚洲一区| 欧美午夜精品久久久| 欧美午夜在线一二页| 国产精品日日摸夜夜摸av| 国产精品亚洲а∨天堂免在线| 国产女人18毛片水18精品| 国产亚洲一级| 香蕉久久久久久久av网站| 老色鬼精品视频在线观看播放| 亚洲欧美日韩网| 久久成人资源| 免费观看一区| 欧美三级欧美一级| 国产美女精品| 亚洲国产综合91精品麻豆| 99精品欧美| 香蕉成人啪国产精品视频综合网| 久久免费少妇高潮久久精品99| 欧美成人激情视频免费观看| 亚洲九九爱视频| 性欧美18~19sex高清播放| 久久婷婷丁香| 欧美午夜视频在线观看| 红桃视频成人| 一本久久综合亚洲鲁鲁五月天 | 国产在线欧美日韩| 亚洲三级国产| 欧美在线影院在线视频| 欧美3dxxxxhd| 亚洲网友自拍| 久久一区二区三区国产精品| 欧美日韩一区二区三区在线| 国产亚洲精品v| 一区二区欧美日韩| 久久综合激情| 中日韩美女免费视频网址在线观看 | 亚洲第一二三四五区| 中文一区在线| 欧美aⅴ一区二区三区视频| 国产精品高潮呻吟| 亚洲精品久久久久久久久久久| 欧美亚洲一区二区在线| 欧美激情久久久久| 欧美亚洲一级| 国产精品sss| 亚洲精品极品| 蜜乳av另类精品一区二区| 亚洲图片欧洲图片av| 欧美精品一卡二卡| 亚洲二区在线| 久久久精品一区| 亚洲一品av免费观看| 欧美精品一区二区三区在线播放| 一区福利视频| 久久婷婷国产综合尤物精品 | 欧美激情精品久久久久久蜜臀 | 国产女精品视频网站免费|