Python 使用C代码——swig

Ref : http://www.swig.org/translations/chinese/tutorial.html

 

假设你有一些c你想再加Python.。举例来说有这么一个文件example.c
 /* File : example.c */
 #include <time.h>
 double My_variable = 3.0;
 int fact(int n) {
     if (n <= 1) return 1;
     else return n*fact(n-1);
 }
 
 int my_mod(int x, int y) {
     return (x%y);
 }

 char *get_time()
 {
     time_t ltime;
     time(&ltime);
     return ctime(&ltime);
 }

 接口文件
现在,为了增加这些文件到你喜欢的语言中,你需要写一个接口文件(interface file)投入到swig中。这些C functions的接口文件可能如下所示:

     /* example.i */
     %module example
     %{
     /* Put header files here or function declarations like below */
     extern double My_variable;
     extern int fact(int n);
     extern int my_mod(int x, int y);
     extern char *get_time();
     %}
    
     extern double My_variable;
     extern int fact(int n);
     extern int my_mod(int x, int y);
     extern char *get_time();
    
      建立Python模块
转换编码C成Python模块很简单,只需要按如下做即可(请见其他操作系统的SWIG 共享库帮助手册):

     unix % swig -python example.i
     unix % gcc -c -fPIC -m32 example.c example_wrap.c /
            -I/usr/(local/include/python2.1)include/python2.4
    unix % (ld)gcc -shared -m32 example.o example_wrap.o -o _example.so

关于以上红蓝绿颜色字解释:
1. -fPIC 我的系统中不加该编译选项时,下面编译-share的库文件会出错。
2. -m32选项,gcc版本高于4.1时,编译出的代码默认是64位的,在执行下面 >>>import example时会出现错误:
ImportError: ./_example.so: wrong ELF class: ELFCLASS64。 而Python这时默认使用的是32位,
这里加-m32选项使gcc编译出32位库代码。[根据自己的系统决定是否添加该选项]
3. 绿色文字括号中的是原文,括号外是我的系统应该使用的路径和命令。[根据自己的系统决定具体路径和命令

我们现在可以使用如下Python模块 :

     >>> import example
     >>> example.fact(5)
     120
     >>> example.my_mod(7,3)
     1
     >>> example.get_time()
     'Sun Feb 11 23:01:07 1996'
     >>>

### 如何使用 SWIG 工具进行接口生成 SWIG 是一种强大的工具,用于简化不同编程语言之间的交互。它能够自动生成多种目标语言(如 Java、Python 等)与 C/C++ 的绑定代码[^1]。 以下是关于如何通过 SWIGC++ 接口封装并提供给 Java 使用的具体方法: #### 准备工作 为了实现这一功能,首先需要准备以下文件: - **C++ 源码**:这是要被封装的核心逻辑。 - **SWIG 接口定义文件 (.i 文件)**:该文件描述了哪些部分的 C++ 功能会被暴露到外部语言中[^2]。 #### 创建 SWIG 接口文件 创建一个 `.i` 文件来指定希望导出的内容。例如假设有一个名为 `example.i` 的文件,其内容可能如下所示: ```swig %module example %{ #include "your_cpp_header.h" %} // 导入头文件中的类或函数声明 %include "your_cpp_header.h" ``` 这里 `%module` 定义模块名称;`%{ ... %}` 块内的代码会原样复制至生成的包装器代码里;而 `%include` 则引入实际使用C++ 类型或者函数声明[^3]。 #### 配置构建环境 对于 Android 平台上的应用开发来说,还需要设置好 NDK 和其他必要的编译选项以便支持 JNI (Java Native Interface)[^4]。 #### 执行命令行操作 完成上述准备工作之后,在终端执行相应的 swig 命令以及后续的标准编译流程即可得到最终产物——可供加载进 JVM 中调用的目标动态库(.so) 或者静态链接库形式的二进制数据包。 示例命令序列可以参考如下模式(假定操作系统为 Linux/MacOSX): ```bash swig -java -c++ -package com.example.swiggenerated example.i g++ -fPIC -I$JAVA_HOME/include -I$JAVA_HOME/include/linux \ -shared your_cpp_source.cpp example_wrap.cxx -o libExample.so ``` 其中 `-java` 参数告诉 SWIG 我们正在为目标语言 Java 构建桥接代码;`-c++` 表明源材料是以 C++ 编写的;其余参数则涉及路径配置等方面的信息调整以适配具体的项目需求情况[^4]。 以上过程概括了一个典型场景下利用 SWIG 实现跨平台间互操作性的基本步骤概述。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值