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编程入门指南pdf-python编程初学者指南
python编程初学者指南是一本边学边制作游戏的经典教程,由美国程序员道森(Michael Dawson)编著.通过阅读本书,你不仅会学到很多实用的Python编程知识,还将懂得如何在实际工作中运用这 ...
- python入门基础代码图-python入门代码指南教程书籍推荐2020总结全集汇总
python入门代码指南教程书籍推荐2020总结全集汇总 记住,如果您想学习Python,市场上有很多可用的资源.这些可以包括书籍,甚至在线课程..在这篇文章中,我们为Python编写了最好的书籍,无 ...
- 史无前例的 HTML5 资源参考指南
2019独角兽企业重金招聘Python工程师标准>>> 尽管 HTML5 规范在 2014 年之前不会有正式版本,很多设计师已经开始试水高级浏览器已经支持的部分 HTML5 功能.H ...
- [译] Cilium:BPF 和 XDP 参考指南(2021)
Cilium:BPF和XDP参考指南_RToax-CSDN博客Table of ContentsBPF体系结构指令系统辅助功能地图对象固定尾叫BPF到BPF呼叫准时制硬化减负工具链开发环境虚拟机本文档 ...
- python入门代码大全-python入门代码指南教程书籍推荐2020总结全集汇总
python入门代码指南教程书籍推荐2020总结全集汇总 记住,如果您想学习Python,市场上有很多可用的资源.这些可以包括书籍,甚至在线课程..在这篇文章中,我们为Python编写了最好的书籍,无 ...
- Python 魔术方法指南
http://pycoders-weekly-chinese.readthedocs.org/en/latest/issue6/a-guide-to-pythons-magic-methods.htm ...
- python代码风格指南_记录Python代码:完整指南
python代码风格指南 Welcome to your complete guide to documenting Python code. Whether you're documenting a ...
- 文档化Python代码完全指南(翻译)
阅读代码比编写代码更多,有良好丰富文档的项目会吸引更多人使用和参与开发贡献.本教程旨在详细阐述如何将 Python 代码实现"文档化",介绍了注释用法.类型提示.文档字符串.在项目 ...
- 使用Matplotlib进行Python绘图(指南)
A picture says a thousand words, and with Python's matplotlib library, it fortunately takes far less ...
最新文章
- 「ImageProcess」mp4视频转存图片内存变大的原因探究
- VIM-配置-.vimrc
- PHP开发自己的框架必备知识点
- android module中获取 app_Android组件化架构 - 4. 动态创建
- 如何有效维护PDH光端机的常见故障?
- Net学习日记_ASP.Net_MVC_新语法笔记
- 英语四六级听力考试选项技巧
- 容器编排技术 -- Kubernetes Namespaces
- 【python】filter()函数
- 什么情况下需要搭建大数据平台
- 整理Java基础知识--数组2
- 一起谈.NET技术,ASP.NET MVC Routing概述
- excel多表格整合去重与空格去除
- myeclipse10异常闪退Java was started but returned exit code=1
- 为什么有的程序员干不到30岁就转行了?
- 网络通信OSI七层或五层模型,路由协议(OSPF,IGRP等)
- 压测--部署jp@gc - PerfMon Metrics Collector
- 夏日炎炎玩转新加坡:盘点室内景点和夜游好去处
- #前端# 如何获取你的token?
- 各类积分对称性详细总结
热门文章
- HTML5 API详解(15):History 不刷新也可以实现网页跳转
- apscheduler 脚本执行失败_在脚本中使用 Bash 信号捕获 | Linux 中国
- Linux全能终端,【MobaXterm】Windows全能终端神器—MobaXterm
- 3串锂电池电量检测ic bq2060pdf及应用原理图_接受电源IC需求挑战,轻松实现精确调节的电源电压!...
- SQLite | Where 子句
- 数学教材里的神秘数表在国外红出圈,网友:引人入胜、猜不到结局
- MIT免费生物信息课程 (代码、文档、数据) - 适合系统学习
- 积微论坛--用微生物组时序数据重现生物膜装配动态过程PPT对应的讲解和提问
- 一文看懂PCA主成分分析
- 华农专业课计算机基础,华南农业大学期末考试大学计算机基础试卷.doc