轉述自 Cxx.jl 官方文檔。
假設有一個ArrayMaker.h和ArrayMaker.cpp(或者在Linux上用.cc後綴,等價於.cpp),首先編譯爲共享庫:
g++ -shared -fPIC ArrayMaker.cpp -o libarraymaker.so
編譯結果爲一個libarrarmaker.so文件。
然後在Julia裏調用:
# 使用Cxx和Libdl
using Cxx, Libdl
# 把庫的路徑存爲一個常數方便引用。pwd()是Julia當前工作目錄,可以把它替換爲libarraymaker.so的實際目錄。
const path_to_lib = pwd();
# 添加頭文件目錄
addHeaderDir(path_to_lib, kind=C_System)
# 添加庫目錄(這裏的庫被稱爲dynamic link library),返回一個指針。
Libdl.dlopen(joinpath(path_to_lib, "libarraymaker.so"), Libdl.RTLD_GLOBAL)
# 包含頭文件
cxxinclude("ArrayMaker.h")
# 現在開始正式使用庫中的內容。首先聲明一個class:
maker = @cxxnew ArrayMaker(5, 2.0)
# 用內部函數填充數組。
arr = @cxx maker->fillarr()
# 可以用unsafe_wrap()解析arr裏的內容,返回的a就是arr裏的數組。
a = unsafe_wrap(Array, arr, 5)
ArrayMaker.h:
#ifndef ARRAYMAKER_H
#define ARRAYMAKER_H
class ArrayMaker {
private:
int inumber;
float fnumber;
float* farr;
public:
ArrayMaker(int, float);
float* fillarr();
};
#endif
ArrayMaker.cpp:
#include "ArrayMaker.h"
#include <iostream>
using namespace std;
ArrayMaker::ArrayMaker(int inum, float fnum) {
cout << "Got arguments: " << inum << " and " << fnum << endl;
inumber = inum;
fnumber = fnum;
farr = new float[inumber];
}
float* ArrayMaker::fillarr() {
cout << "Filling the array" << endl;
for (int i = 0; i < inumber; i++) {
farr[i] = fnumber;
fnumber *= 2;
}
return farr;
}