C 和 C++++ 被公認為(理當如此)創建高性能代碼的首選平臺。 對HTTP://www.aliyun.com/zixun/aggregation/7155.html">開發人員的一個常見要求是向指令碼語言介面公開 C/C++ 代碼,這正是 Simplified Wrapper and Interface Generator (SWIG) 的用武之地。 SWIG 允許您向廣泛的指令碼語言公開 C/C++ 代碼,包括 Ruby、Perl、Tcl 和 Python。 本文使用 Ruby 作為公開 C/C++ 功能的首選指令碼介面。 要理解本文,您必須具備 C/C++ 與 Ruby 方面的相應知識。
SWIG 是一款不錯的工具,可適合多種場景,其中包括:
向 C/C++ 代碼提供一個指令碼介面,使使用者更容易使用向您的 Ruby 代碼添加擴展或將現有的模組替換為高性能的替代模組提供使用腳本環境對代碼執行單元和集成測試的能力使用 TK 開發一個圖形使用者介面並將它與 C/C++ 後端集成此外,與 GNU Debugger 每次都需觸發相比,SWIG 要容易調試得多。
SWIG 安裝
本文使用了 SWIG 版本 2.0.4(參見 參考資料 獲取下載網站的連結)。 要構建和安裝 SWIG,可按照典型的開源安裝流程,在命令提示符下輸入以下命令:
tar xvzf swig-2.0.4.tar.gz
./configure –prefix=/your/swig/install/path
make
make install
請注意,為首碼提供的路徑必須是絕對路徑。
Ruby 環境變數
SWIG 生成包裝器 C/C++ 代碼時需要 ruby.h 來保證進行正確的編譯。 在您的 Ruby 安裝中檢查 ruby.h:一種建議的做法是將環境變數 RUBY_INCLUDE 指向包含 ruby.h 的資料夾,將 RUBY_LIB 指向包含 Ruby 庫的路徑。
使用 SWIG 編寫 Hello World
作為輸入,SWIG 需要一個包含 ANSI C/C++ 聲明和 SWIG 指令的檔。 我將此輸入檔稱為 SWIG 介面檔。 一定要記住,SWIG 僅需要足夠生成包裝器代碼的資訊。 該介面檔通常具有 *.i 或 *.swg 副檔名。 以下是第一個擴展檔 test.i:
%module test%constant char* Text = "Hello World with SWIG"
使用 SWIG 運行此代碼:
swig –ruby test.i
第二個程式碼片段中的命令列在當前資料夾中生成一個名為 test_wrap.c 的檔。 現在,您需要在此 C 檔中創建一個共用庫。 以下是該命令列:
bash$ gcc –fPIC –c test_wrap.c –I$RUBY_INCLUDEbash$ gcc –shared test_wrap.o –o test_wrap.so –lruby –L$RUBY_LIB
就這麼簡單。 您已準備就緒,那就觸發互動式 Ruby shell (IRB),輸入 require 'test_wrap' 來檢查 Ruby Test 模組和它的內容。 以下是擴展的 Ruby 端:
irb(main):001:0> require 'test_wrap'=> trueirb(main):002:0> Test.constants=> ["Text"]irb(main):0 03:0> Test:: Text=> "Hello World with SWIG"
SWIG 可用於生成各種語言擴展,只需運行 swig –help 檢查所有的可用選項。 對於 Ruby,可以輸入 swig –ruby <interface file>;對於 Perl,可以使用 swig –perl <interface file>。
也可以使用 SWIG 生成 C++ 代碼:只需在命令列使用 –c++ 即可。 在前面的示例中,運行 swig –c++ –ruby test.i 會在當前資料夾中生成一個名為 test_wrap.cxx 的檔。