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

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Unix環境下嵌入式C程序編譯

            Posted on 2012-03-21 13:45 Prayer 閱讀(1765) 評論(0)  編輯 收藏 引用 所屬分類: C/C++LINUX/UNIX/AIXDB2makefile
            A.預編譯部分
            1.預編譯DB2篇
            1.1 什么是DB2預編譯
              在我們用C語言編寫訪問DB2的程序過程中,需要用到嵌入式SQL,其作用是將DB2 SQL混入一般C程序中, DB2預編譯器可以將SQL語法直接轉換為DB2行時服務應用程序編程接口(API)調用。
            1.2 什么是bind
              這是DB2 prep要做的事情,即把SQC中的SQL語句變為DB2數據庫可認的API。bind的作用主要是根據你SQC中的SQL語句使用的表和操作指定一個訪問時DB要使用的策略,是一種優化作用,加快數據訪問的速度;當然也可以不bind,那樣,訪問的過程策略是在訪問時才有的,速度會受很大的影響,特別是并發訪問。

            2.預編譯命令
              2.1 db2 prep .sqc文件 bindfile 其中bindfile參數作用是生成和sqc文件同名的.bnd文件
            例: db2 prep /export/home/shwhome/sqc/CON_DB2.sqc bindfile 如果編譯正常完成,則在.sqc文件同目錄下會生成CON_DB2.c和CON_DB2.bnd文件
            2.2 bind .bnd文件
              例: db2 bind /export/home/shwhome/sqc/CON_DB2.bnd
            因為是DB2的預編譯命令,使用的是DB2的預編譯器,所以以上兩條命令需要在連接DB2數據庫的情況下才可以使用

            B.嵌入式部分
            1.嵌入式C程序的編譯
            我們采用GCC來編譯C程序,GCC的一般編譯命令請參考文檔中的相關說明,這里具體說明在目前環境下編譯C程序的注意點。
            1.1 編譯C程序
            gcc -m64 -c -I/export/home/shwhome/inc -o /export/home/shwhome/obj/testdb.o /export/home/shwhome/src/testdb.c
            參數說明
            -m64: 在64位服務器上編譯時采用,這里為了將所有的編譯后的目標文件統一,所以都加上-m64,如果再之后引用目標文件沒有采用-m64編譯則在最后編譯時會出現ELF CLASS32(或ELF CLASS64)錯誤. -C: 只編譯并生成目標文件,不做鏈接。
            1.2 編譯SQC文件生成的.C文件
            gcc -m64 -c -I/export/home/shwhome/inc -I/export/home/aix/sqllib/include -L/usr/include/lib -o /export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/sqc/CON_DB2.c
            參數說明
            -I/export/home/aix/sqllib/include: 這個目錄下主要使用到2個頭文件:sqladef.h和sqlca.h,這個是DB2預編譯包含的都文件,可以查看你用prep編譯出來的與.sqc同名的.C文件,其中就包含這兩個頭文件。其中aix是DB2Instance用戶,DB2安裝后會將include路徑復制到instance用戶的環境變量中,再次創建instance后只要復制過來就可以,因為Instance用戶還包含其他的環境設定,所以不要直接引用-I/opt/IBM/db2/V9.5/include/這個DB2的安裝路徑
            -L/usr/include/lib: 這個目錄是系統包含函數的庫文件,是編寫應用程序的時候使用的相當于API,也就是應用編程接口。
            ※ -I/usr/include和-L/usr/include/lib是將usr/include下的函數作為頭文件包括進來,并且將程序鏈接到庫文件,這個例子中沒有用到,但是如果保險的話,在編譯時最好加上這兩個選項。
            1.3 將兩個目標文件(主體C程序和嵌入式SQL)編譯成可執行程序
            gcc -m64 -ldb2 -lc -o /export/home/shwhome/bin/testdb /export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/obj/testdb.o
            參數說明
            -ldb2: 鏈接DB2庫文件。在SQC程序編譯時必須鏈接libdb2.so庫,其路徑是/usr/lib/krb5/libdb2.so,之所以寫成-ldb2,是在使用-l時,將庫名的lib和后綴都去除,即庫名是db2。以上命令是引用/export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/obj/testdb.o這兩個目標文件,編譯后生成testdb,放在路徑/export/home/shwhome/bin下。
            久久婷婷色香五月综合激情| 亚洲?V乱码久久精品蜜桃| 国产69精品久久久久9999APGF| 一级做a爰片久久毛片16| 久久99精品久久久久久齐齐| 亚洲国产精品18久久久久久| 97超级碰碰碰碰久久久久| 热99RE久久精品这里都是精品免费 | 99久久国产综合精品成人影院| 久久无码人妻精品一区二区三区| 天天躁日日躁狠狠久久| 欧美久久一级内射wwwwww.| 国产亚洲婷婷香蕉久久精品| 亚洲午夜福利精品久久| 久久综合狠狠综合久久激情 | 久久精品中文字幕无码绿巨人| 日韩一区二区三区视频久久| 亚洲综合婷婷久久| 香港aa三级久久三级| 人妻精品久久久久中文字幕69 | 久久精品国产精品国产精品污| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 无码8090精品久久一区 | 国产精品gz久久久| 久久精品www| 欧美激情精品久久久久| 69国产成人综合久久精品| 亚洲精品tv久久久久久久久 | 国产成人无码精品久久久免费 | 欧美伊人久久大香线蕉综合| 欧美久久亚洲精品| 中文字幕无码久久精品青草 | 一本色道久久综合狠狠躁篇| 色婷婷久久久SWAG精品| 伊人久久大香线蕉无码麻豆| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久精品aⅴ无码中文字字幕不卡| 午夜精品久久影院蜜桃| 国产精品乱码久久久久久软件 | 波多野结衣久久| 亚洲国产精品无码久久|