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

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>
            欧美亚洲免费电影| 一区二区免费在线观看| 久久国产66| 亚洲欧美资源在线| 精品不卡在线| 亚洲高清免费视频| 欧美经典一区二区| 亚洲欧美伊人| 欧美专区亚洲专区| 亚洲激情自拍| 一区二区三区波多野结衣在线观看| 欧美四级电影网站| 久久免费午夜影院| 欧美日韩国产精品成人| 亚洲欧洲99久久| 久久野战av| 亚洲视频视频在线| 久久精品九九| 亚洲在线观看视频| 久久九九99视频| 一区二区免费看| 久久久久久久久久看片| 一本色道久久综合亚洲精品高清| 亚洲综合日韩| 亚洲人成在线影院| 亚洲欧美日韩中文视频| 亚洲黄色在线| 欧美一区二区性| 亚洲视频在线一区| 久久一区免费| 欧美影院视频| 欧美特黄一区| 亚洲国产天堂久久综合| 国产亚洲毛片| 一区二区冒白浆视频| 亚洲国产激情| 久久不射2019中文字幕| 亚洲一二三区在线| 欧美va天堂va视频va在线| 久久狠狠婷婷| 国产精品人人爽人人做我的可爱| 亚洲国产成人av好男人在线观看| 国产欧美日韩亚洲一区二区三区| 亚洲精选中文字幕| 亚洲全部视频| 久久婷婷国产综合尤物精品| 香蕉av福利精品导航| 国产精品电影观看| 亚洲精品影视| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品网站在线播放gif| 欧美日韩另类视频| 亚洲性视频网址| 久久国产精品电影| 亚洲人成啪啪网站| 欧美日韩精品三区| 欧美一区二区三区视频在线| 欧美成人精品在线播放| 亚洲精品欧洲精品| 国产日产欧产精品推荐色| 欧美成人一品| 欧美成人乱码一区二区三区| 国产一区二区三区四区五区美女| 一二三区精品| 亚洲欧美日本视频在线观看| 欧美午夜精品理论片a级大开眼界 欧美午夜精品理论片a级按摩 | 免播放器亚洲| 亚洲第一网站| 亚洲另类在线一区| 欧美区视频在线观看| 亚洲精品欧美日韩专区| 一区二区欧美在线观看| 欧美视频一区二区三区四区| 妖精成人www高清在线观看| 制服诱惑一区二区| 国产精品区免费视频| 欧美专区在线观看| 久久中文精品| 亚洲美女精品久久| 欧美视频一区二区三区| 亚洲欧美日韩一区二区在线 | 欧美一级午夜免费电影| 久久只有精品| 日韩视频在线免费观看| 欧美午夜精彩| 久久久欧美精品sm网站| 亚洲国产欧美日韩| 亚洲女同在线| 一区二区三区在线观看视频| 欧美成人第一页| 中文国产成人精品| 麻豆av福利av久久av| 亚洲美女黄网| 国产在线观看精品一区二区三区| 欧美大片国产精品| 亚洲伊人伊色伊影伊综合网| 免费在线一区二区| 亚洲线精品一区二区三区八戒| 国产日韩欧美不卡| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲精品乱码视频| 久久久久久久91| 日韩视频在线观看| 亚洲风情亚aⅴ在线发布| 伊人久久亚洲影院| 欧美日韩国产在线看| 欧美伊人久久| 一区二区成人精品| 欧美国产视频在线观看| 午夜亚洲福利在线老司机| 亚洲欧洲在线播放| 国产婷婷色一区二区三区四区| 欧美高清自拍一区| 久久久久国产一区二区| 亚洲视频大全| 亚洲乱码精品一二三四区日韩在线 | 欧美日韩大片| 久久综合一区二区| 亚洲免费综合| 一区二区三欧美| 亚洲国产一区视频| 久热综合在线亚洲精品| 欧美中文字幕在线视频| 亚洲自拍16p| 亚洲手机在线| 日韩午夜av| 亚洲精品日韩在线| 亚洲高清在线观看一区| 国产在线成人| 国产一区二区三区不卡在线观看| 欧美亚州韩日在线看免费版国语版| 男男成人高潮片免费网站| 久久久久久999| 久久精品国产亚洲一区二区三区| 亚洲在线观看免费视频| 亚洲最新在线| 一区二区三区四区五区在线 | 欧美在线关看| 午夜在线视频观看日韩17c| 亚洲一区二区三区欧美 | 国内久久婷婷综合| 国产欧美韩国高清| 国产农村妇女精品一区二区| 国产精品久久福利| 欧美偷拍一区二区| 欧美午夜视频网站| 国产精品视频不卡| 国产精品亚洲一区二区三区在线| 国产精品美女久久久久久久| 国产乱码精品1区2区3区| 国产日产欧美一区| 国产又爽又黄的激情精品视频| 国产一区二区三区在线观看网站| 国产欧美日韩不卡免费| 韩国精品在线观看| 91久久夜色精品国产网站| 亚洲激情成人网| 一区二区三区四区在线| 亚洲欧美一区二区三区久久| 午夜视黄欧洲亚洲| 麻豆精品精华液| 亚洲电影网站| 在线视频日韩精品| 午夜精品视频在线| 久久综合伊人77777| 欧美精品久久天天躁| 国产精品v欧美精品∨日韩| 国产欧美精品在线播放| 136国产福利精品导航| 一本久久综合亚洲鲁鲁五月天| 亚洲午夜成aⅴ人片| 久久久久高清| 亚洲精品1区2区| 亚洲欧美精品一区| 久久综合伊人77777尤物| 欧美日韩伊人| 一区精品在线| 亚洲网友自拍| 国产日产高清欧美一区二区三区| 在线综合+亚洲+欧美中文字幕| 亚洲综合99| 欧美成人国产| 激情国产一区二区| 亚洲午夜高清视频| 久久一区亚洲| 亚洲一二三四久久| 欧美.www| 国内精品久久久久久久影视麻豆| 亚洲欧洲在线看| 久久久久久久波多野高潮日日| 亚洲激情综合| 久久精品123| 国产精品视频午夜| 99国产精品久久久久老师| 久久久99精品免费观看不卡| 一本大道久久a久久综合婷婷 | 午夜精品视频在线观看一区二区 | 亚洲午夜av在线| 欧美极品aⅴ影院| 国语自产精品视频在线看8查询8|