转自here
SWIG是个帮助使用C或者C++编写的软件能与其它各种高级编程语言进行嵌入联接的开发工具。
SWIG能应用于各种不同类型的语言,包括常用脚本编译语言,例如Perl, PHP, Python, Tcl, Ruby 和 PHP。
SWIG普遍应用于创建高级语言解析或汇编程序环境、用户接口、作为一种用来测试C/C++或进行原型设计的工具。
工作中碰到了一个小问题:有一个加密/解密的程序原本是用C++语言写的,后来需要用Python来实现调用。简单粗暴的办法是照着C++代码重写一个Python版本的程序,但是很麻烦,还会带来以下问题:
- 时间成本,开发方面需要些代价
- 维护成本,需要自己维护,重复造*
- 代码冗余,多套代码,不易维护
后来经老手介绍,知道可以用SWIG来把C++的代码封装成Python库,供Python调用。
SWIG (Simplified Wrapper and Interface Generator) 是用来为C和C++程序构造脚本语言接口的软件开发工具。SWIG 实际上是一个编译器,获取C/C++的声明,用一个壳包起来,以便通过其他语言访问这些声明。因此,SWIG 最大的好处就是将脚本语言的开发效率和 C/C++ 的运行效率结合起来。
1 原始文件
编写好原始的h和cpp文件,示例如下:
1 |
//File: EncryptTool.h |
2 编写.i接口文件
新增加文件EncryptTool.i,内容如下:
1 |
//File: EncryptTool.i |
.i接口文件中主要包含了三个部分:
%module
后面的名字是被封装的模块名称,Python通过这个名称加载程序。%{...%}
之间所添加的内容,一般包含此文件需要的一些函数声明和头文件。- 最后一部分,声明了要封装的函数和变量。
如果把要封装的函数声明部分写在了头文件里,最后一部分直接用%include
包含头文件名也行:
1 |
//File: EncryptTool.i |
两种.i文件的效果是一样的,比较建议使用第二种方法,能够简化接口文件
3 封装代码
执行以下命令对c++代码进行封装:
1 |
swig -python -c++ EncryptTool.i |
执行完毕后会生成EncryptTool.py和EncryptTool_wrap.cxx这两个文件,相当于将原cpp文件进行了封装,wrap了一层
4 生成动态链接库
编写setup.py文件,用于自动化编译动态链接库:
1 |
#File: setup.py |
编写完成后执行以下命令进行编译:
1 |
python setup.py build |
编译通过后在build/lib.*
开头的子目录下即可见到编译好的Python库文件:_EncryptTool.so和EncryptTool.py
5 在Python加载库
通过以下方式调用所生成的动态链接库即可:
1 |
import EncryptTool |