Python - SIP参考指南 - 介绍
介绍
本文是SIP4.18的参考指南。SIP是一种Python工具,用于自动生成Python与C、C++库的绑定。SIP最初是在1998年用PyQt开发的,用于Python与Qt GUI toolkit的绑定,但适用于生成任何C或C++库的绑定。
此版本SIP生成的绑定可用于Python 2.3以后的版本,包括Python 3.x。
还有许多其他类似的工具,例如SWIG。事实上,SIP如此名字是因为它源于一个小型的SWIG。但不像SWIG,SIP是特别设计于将Python与C/C++进行绑定的,它尽可能地集成更多C/C++的功能。
SIP官网:http://www.riverbankcomputing.com/software/sip
在这里你总能找到最新的稳定版与最新版的文档。
SIP也可以从Mercurial库下载:http://www.riverbankcomputing.com/hg/sip.
许可
SIP许可类似于Python,也采用GPL协议(包括v2和v3)。如果你使用SIP,意味着你必须遵循GPL协议。
特征
SIP和它所生成的绑定拥有如下特征:
- 加载迅速,内存占用低。
- 自动转换标准的Python与C/C++数据类型。
- 不同参数签名的函数和方法的重载
- 访问C++类的protected方法
- 能够定义一个继承于C++类型的Python子类,包括C++抽象类
- Python子类可以实现__dtor__()方法来支持C++类的虚析构函数的调用。
- 支持普通C++函数、类方法、静态类方法、虚类方法和抽象类方法。
- 可以在Python中重新实现C++虚/抽象方法
- 支持全局和Class变量
- 支持全局和Class操作
- 支持C++命名空间
- 支持C++模板
- 支持C++异常并转换为Python异常
- 丰富的comparsion slots的自动生成
- 支持deprecation警告
- 支持定义C++类与相似的Python数据类型的映射,并自动调用
- 支持自动利用任何可用的运行时类型信息,确保Python实例对象类型与对应的C++对象实例相匹配
- 可以转换在类型与meta类型之间转换python对象,用以包装一个C/C++数据类型
- 支持Python全局解释器锁,包括指示一个C++函数可能被阻塞,从而允许释放锁,让其他Python线程运行。
- 支持将多个简单的或私有相关的模块合并为一个模块。
- 支持C++实例所有权概念(即代码的哪些部分负责调用实例的析构函数),支持所有权在应用程序运行期间的改变。
- 产生一个本身建立在其他C++类库之上的C++类库,允许不同的bindings之间代码集成与共享。
- 支持用一套规范的文件,定义复杂的版本控制系统。允许控制C++类库的全生命周期,包括指定特定于平台的可选功能。
- 支持自动生成PEP 484 类型hint stub文件,可以在指定的文件中包含说明文档,并允许外部工具提取和处理。
- 可以在所有生成的源码中自动包含规范文件中所声明的版权和授权信息。
- 可以在Python书写的构建系统中继承配置,编译并且安装你自己的绑定,从而无需担心平台的具体问题。
- 使用distutils构建你的扩展支持。
- SIP以及其生成的bindings,可以运行在UNIX,Linux,Windows,MacOS/X,Android and iOS中
SIP组件
SIP由一些不同的组件构成。
- SIP代码生成器。它处理.sip规范文件并生成C或C++bindings。转换详情参考《使用SIP(Using SIP)》一节。
- SIP头文件(sip.h)。它包含生成C与C++代码所需要的规范与数据结构。
- SIP模块(sip.so或sip.pyd)。这是一个python扩展模块,自动由SIP生成的bindings导入,并为它们提供一些通用的工具函数。详情参考《应用程序Python API(Python API for Applications)》
- SIP构建系统(sipconfig.py)。它是一个纯python模块,在SIP被配置并封装所有系统的相关信息时被创建。它包含目录名称、编译和链接标志以及版本号,它也包含一些Python类与函数。它帮助你为bindings编写配置脚本。
- SIP distutils扩展(sipdistutils.py)。这是一个distutils扩展,可以用distutils构建你的扩展模块。用于替代手动编写SIP构建系统的配置脚本。它可以很简单的添加.sip文件到你需要构建和扩展的文件清单。详情参见《用distutils构建扩展(Building Your Extension with distutils)》。
SIP v5的准备
SIP指定文件的语法将在SIP v5中改变。SIP代码生成器的命令行选项也会改变。为了帮助用户管理过度,将采用以下方法
- 尽可能把所有不兼容的变更,首先在SIP v4中实现。
- 不兼容的变更实现之后,老的语法将被指定为deprecated(提示警告),但仍然在v4中支持。
Qt支持
SIP为创建基于Digia的Qt 工具包提供支持。
SIP代码生成器理解signal/slot类型安全的回调机制,该机制被Qt用于把对象连接到一起。它允许应用程序定义新的Python signals,并且允许python调用对象可以像slot一样使用。
Python - SIP参考指南 - 介绍的更多相关文章
- python之魔法方法介绍
1.1. 简介 什么是魔法方法呢?它们在面向对象的Python的处处皆是.它们是一些可以让你对类添加“魔法”的特殊方法. 它们经常是两个下划线包围来命名的(比如 __init__ , __lt__ ) ...
- PEP 8 - Python代码样式指南
PEP 8 - Python代码样式指南 PEP: 8 标题: Python代码风格指南 作者: Guido van Rossum <python.org上的guido>,Barry Wa ...
- Python 编码风格指南
原文:http://python.jobbole.com/84618/ 本文超出 PEP8 的范畴以涵盖我认为优秀的 Python 风格.本文虽然坚持己见,却不偏执.不仅仅涉及语法.模块布局等问题,同 ...
- (转)PEP 8——Python编码风格指南
PEP 8——Python编码风格指南标签(空格分隔): Python PEP8 编码规范原文:https://lizhe2004.gitbooks.io/code-style-guideline-c ...
- Python开发人员指南
本指南是一个全面的资源贡献 给Python的 -为新的和经验丰富的贡献者.这是 保持由维护的Python同一社区.我们欢迎您对Python的贡献! 快速参考 这是设置和添加补丁所需的基本步骤.了解基础 ...
- PEP8中文版 -- Python编码风格指南
Python部落组织翻译, 禁止转载 目录 缩进 制表符还是空格? 行的最大长度 空行 源文件编码 导入 无法忍受的 其 ...
- Nmap参考指南中文版
Nmap参考指南中文版 来源: http://www.nmap.com.cn/doc/manual.shtm 译注 该Nmap参考指南中文版由Fei Yang <fyang1024@gmail. ...
- PHP程序员进阶学习书籍参考指南
PHP程序员进阶学习书籍参考指南 @heiyeluren lastmodify: 2016/2/18 [初阶](基础知识及入门) 01. <PHP与MySQL程序设计(第4版)> ...
- python Scrapy安装和介绍
python Scrapy安装和介绍 Windows7下安装1.执行easy_install Scrapy Centos6.5下安装 1.库文件安装yum install libxslt-devel ...
随机推荐
- 我的第一篇blog—— 一起来赛马呀
作为一名大三的学生现在开始学习acm,或许太晚.感叹时光蹉跎....我的blog将以讲解的形式的发布,以专题的形式的形式介绍一些基本的知识和经典的题目.虽然感觉自己所剩时间无多,但也希望起到前人种 ...
- python的urlparse
urlparse主要是URL的分解和拼接,分析出URL中的各项参数,可以被其他的URL使用. 主要的函数有: 1.urlparse 将URL分解为6个片段,返回一个元组,包括协议.基地址.相对地址等等 ...
- elasticsearch的映射(mapping)和分析(analysis)
转发自:http://blog.csdn.net/hzrandd/article/details/47128895 分析和分析器 分析(analysis)是这样一个过程: 首先,表征化一个文本块为适用 ...
- MySQL主从复制 + Mycat实现读写分离
说明:两台MySQL服务器都是使用CentOS6.5系统,MySQL版本为mysql-5.7.17 MySQL一主一被实现主从复制 注意:写包括insert,delete,update 操作:读只有s ...
- 使用 Proxy + Promise 实现 依赖收集
(深入浅出Vue基于“依赖收集”的响应式原理) ,这篇文章讲的是通过一个通俗易懂例子,介绍了 如何用Object.defineProperty 实现的“依赖收集”的原理.Object.definePr ...
- 面试题:Two Sum
Given an array of integers, return indices of the two numbers such that they add up to a specific ta ...
- win10 uwp 获得焦点改变
本文讲的是当我们应用失去焦点时,我们获得事件,当我们应用获得焦点,同样获得事件.同时,在应用不可以见时,我们也可以获得. 上面一张图,开始是应用启动,获得焦点,应用显示.然后我们打开另一个应用,切换, ...
- Bootstrap 禁用滚动条
Bootstrap中禁用滚动条的方法 逻辑: 当点击弹窗按钮后,js会为body元素添加一个modal-open的类,该类主要内容如下 .modal-open .modal { overflow-x: ...
- php header的使用,PHP常见header状态总结
<?php//200 正常状态header('HTTP/1.1 200 OK');// 301 永久重定向,记得在后面要加重定向地址 Location:$urlheader('HTTP/1.1 ...
- 基于8211lib库对s57电子海图的解析和存储
电子海图是为适用航海需要而绘制的包含海域地理信息和航海信息的一种数字化的专题地图,符合国际标准的电子海图数据统称为S-57电子海图.本文主要在S-57电子海图数据的理论模型和数据结构的基础上,实现对S ...