• <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>

            小明思考

            高性能服務(wù)器端計(jì)算
            posts - 70, comments - 428, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            如何寫(xiě)出專業(yè)的C頭文件

            Posted on 2007-05-15 13:38 小明 閱讀(10423) 評(píng)論(7)  編輯 收藏 引用 所屬分類: C/C++
             

            做到專業(yè),應(yīng)該是每個(gè)職業(yè)程序員應(yīng)該要求自己做到的。
            讓我們看看lua是怎么寫(xiě)頭文件的。

            1.License Agreement
            License Agreement
            應(yīng)該加在每個(gè)頭文件的頂部。
            Lua Sample:

             

            /*
            ** $Id: lua.h,v 1.175b 2003/03/18 12:31:39 roberto Exp $
            ** Lua - An Extensible Extension Language
            ** Tecgraf: Computer Graphics Technology Group, PUC-Rio, Brazil
            ** 
            http://www.lua.org    mailto:info@lua.org
            ** See Copyright Notice at the end of this file
            */

             


            2.guard define
            整個(gè)頭文件應(yīng)該在guard define之間

            #ifndef lua_h
            #define lua_h

            #endif

             另外,如果這個(gè)頭文件可能給c++使用,要加上

            #ifdef __cplusplus
            extern "C" {
            #endif
            /*The lines within extern "C" */



            #ifdef __cplusplus
            }
            #endif

             
            3.盡量不要在頭文件中暴露數(shù)據(jù)結(jié)構(gòu)

            這樣可以用戶降低對(duì)你的實(shí)現(xiàn)的依賴,也減少了用戶的編譯時(shí)間

             

            typedef struct lua_State lua_State;
            LUA_API lua_State 
            *lua_open (void);
            LUA_API 
            void       lua_close (lua_State *L);

             可以看到雖然用戶會(huì)一直使用lua_State,但是并不知道lua_State的結(jié)構(gòu)是什么

            從一個(gè)使用lua的例子程序可以看出:

             

            #include "lua.h"
            #include 
            "lauxlib.h"
            #include 
            "lualib.h"

             

            int main(int argc, char *argv[])
            {
                lua_State 
            *= lua_open();
                
            const char *buf = "var = 100";
                
            int var ;
                luaopen_base(L);
                luaopen_io(L);
                lua_dostring(L, buf);
                lua_getglobal(L, 
            "var");
                var 
            = lua_tonumber(L, -1);
                lua_close(L);
                
            return 0;
            }

             

            4.函數(shù)聲明前加XXX_API已利于拓展

             Lua的例子

            #ifndef LUA_API
            #define LUA_API              extern
            #endif

            LUA_API lua_State 
            *lua_open (void);


            如果定義了LUA_API就是給LUA內(nèi)部使用的

            如果沒(méi)定義LUA_API就是for user

            寫(xiě)Window dll程序經(jīng)常會(huì)用到

             

            #ifdef DLLTEST_EXPORTS
            #define DLLTEST_API __declspec(dllexport)
            #else
            #define DLLTEST_API __declspec(dllimport)
            #endif

             

             

            5.宏的定義

            盡量使用括號(hào)來(lái)包住所定義的對(duì)象

             

            #define LUA_TNONE       (-1)

            #define lua_register(L,n,f) \
                   (lua_pushstring(L, n), \
                    lua_pushcfunction(L, f), \
                    lua_settable(L, LUA_GLOBALSINDEX))

             
            6.目錄結(jié)構(gòu)

            一般應(yīng)該使用一個(gè)單獨(dú)的include目錄來(lái)包含要發(fā)布的頭文件,但不應(yīng)該把內(nèi)部使用的頭文件包含進(jìn)去。

            Lua   include目錄只包含了三個(gè)頭文件

            lauxlib.h , lua.h, lualib.h

            非常簡(jiǎn)潔

            Feedback

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2007-05-17 11:49 by 丑石
            總結(jié)的不錯(cuò)!

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2007-05-18 23:07 by Qiu Xianli
            值得學(xué)習(xí)一下。

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2007-09-01 22:48 by 螞蟻終結(jié)者
            不錯(cuò),學(xué)習(xí)了。

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2007-10-17 10:04 by 螞蟻終結(jié)者
            都是相當(dāng)實(shí)用的,不錯(cuò)。

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2008-01-23 16:41 by icqanki
            的確不錯(cuò).

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2008-07-03 18:23 by pantree
            謝謝了,不錯(cuò),啟發(fā)很多。最近正為這個(gè)頭疼

            # re: 如何寫(xiě)出專業(yè)的C頭文件  回復(fù)  更多評(píng)論   

            2010-01-20 10:34 by xx
            支持,總結(jié)得不錯(cuò)
            久久久久99精品成人片直播| 久久se精品一区精品二区国产| 亚洲AV成人无码久久精品老人| 久久久噜噜噜www成人网| 国产精品九九久久免费视频 | 亚洲中文字幕无码久久精品1| 久久夜色精品国产欧美乱| 久久久精品波多野结衣| 2020久久精品国产免费| 久久成人小视频| 国产精品一区二区久久精品无码 | 亚洲国产精品人久久| 精品久久久久久中文字幕大豆网 | 午夜天堂av天堂久久久| 亚洲国产高清精品线久久| 精品一区二区久久久久久久网站| 久久久久青草线蕉综合超碰| 久久久久亚洲AV无码去区首| 91久久精品91久久性色| 久久久无码一区二区三区| 亚洲精品乱码久久久久久自慰| 欧美激情精品久久久久久久| 国产精品一区二区久久精品无码| 99精品国产在热久久无毒不卡| 亚洲精品午夜国产VA久久成人| 伊人久久一区二区三区无码| 久久精品国产精品亚洲人人| 狠狠狠色丁香婷婷综合久久五月| 久久er99热精品一区二区| 日日躁夜夜躁狠狠久久AV| 7777久久久国产精品消防器材| 久久久久久久久久久精品尤物 | 国产精品一久久香蕉国产线看| 少妇高潮惨叫久久久久久| 欧洲人妻丰满av无码久久不卡| 久久免费看黄a级毛片| 日产精品99久久久久久| 久久人人爽爽爽人久久久| 久久99精品国产自在现线小黄鸭| 久久精品国产亚洲AV无码娇色| 69国产成人综合久久精品|