- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试学习 SWIG,尝试将它与 python 中的其他 C++ 包装器进行比较。我想写的功能之一是这样的:
obj = MyObj()
obj.add([(1,2,), (3,4.0,), (5,"six","string",)])
add
需要获取一个元组列表,这些元组的大小要么是 2 要么是 3,并且不是所有统一类型(因为,你知道,Python)。在 SWIG 中执行此操作的最简单方法是什么(最终我希望此代码调用 obj.add_int(1, 2)
、obj.add_double(3, 4.0)
,在实际的 C++ 对象上)。
最佳答案
如果是我在 SWIG 中这样做,我会尽量编写尽可能少的奇怪的额外代码。因此,我最初的方法是编写一些 Python 代码来处理异构列表,并确定为列表中的每个条目调用哪个 add_TYPE
。
举个例子:
%module test
%{
#include <iostream>
#include <limits>
%}
%include <std_string.i>
%inline %{
struct MyObj {
void add_double(unsigned a, const double& b, const double& c=std::numeric_limits<double>::quiet_NaN()) {
std::cout << "add_double(): " << a << ", " << b << ", " << c << "\n";
}
void add_int(unsigned a, int b, int c=~0) {
std::cout << "add_int(): " << a << ", " << b << ", " << c << "\n";
}
void add_string(unsigned a, const std::string& b, const std::string& c="") {
std::cout << "add_string(): " << a << ", " << b << ", " << c << "\n";
}
};
%}
%pythoncode %{
def obj_add(self, items):
tries = (self.add_int, self.add_double, self.add_string)
for args in items:
for method in tries:
good = False
try:
method(*args)
except NotImplementedError:
pass # Just pick a different version
else:
good = True
break
if not good: raise TypeError('No matches')
MyObj.add = obj_add
%}
为了方便演示,我在一个 %inline
指令中声明、定义和包装了所有 MyObj
。您可能对此略有不同,例如重载而不是默认参数来区分两个/三个 arg 版本可能很有意义,并且也可以与 SWIG 一起“正常工作”。
add
的魔力完全是用 Python 使用老式的 ducktyping 编写的。作为纯 Python,您可能想要采用的所有常用方法都是开放的 - 遍历列表并使用 try
来处理失败,直到我选择一个工作。 (值得注意的是,你尝试它们的顺序很重要——如果 double 出现在 int 之前,那么你永远不会选择 int 而不是 double)。
这足以让我运行:
from test import *
obj = MyObj()
obj.add([(1,2,), (3,4.0,), (5,"six","string",)])
print('Done')
一旦我编译了它:
swig -py3 -c++ -python -Wall test.i
g++ -Wall -Wextra test_wrap.cxx -I/usr/include/python3.4/ -lpython3.4m -shared -o _test.so
结果如预期:
add_int(): 1, 2, -1
add_double(): 3, 4, nan
add_string(): 5, six, string
Done
您可以通过多种其他方式解决此问题,最明显的其他选择是使用大量 Python C API 调用(PyFloat_Check
、PyInt_Check
等),但是当我们只能依赖现有的 SWIG 行为时,编写更难的代码来维护代码似乎需要付出很多努力。
关于python - swig 将元组列表传递给 C++ 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26999073/
我正在制作一个 C++ 库的包装器,以便它可以从 Java 中使用,我正在用 Swig 做这个。 我面临的是我有一个类(class) SomeClass ,它有一些重载的方法( someMethod
我有许多要在 SWIG 中重命名的类。我的大部分类(class)看起来像这样some_class ,我想将其重命名为 SomeClass .这很简单: %replace("%(camelcase)s"
PyPy 有一些 compatibility limitations ,尤其是关于 CPython C API。 我用 QuickFix预编译的 SWIG 绑定(bind)附带的包,我正在考虑将它与
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
使用 SWIG 生成接口(interface)模块时,生成的 C/C++ 文件包含大量静态样板函数。因此,如果想通过在同一个应用程序中使用许多单独编译的小接口(interface)来模块化 SWIG
我正在应用 SWIG 手册中有关嵌套类的解决方法,该部分使用全局内部类。在这里,我将向您展示一个类似于手册中的版本,但为您尽可能地简化了。我还必须将内联定义 {} 添加到 method(),因为没有它
我有一个现有的库 (JPhysX),它是原生 C++ 库 (PhysX) 的 Java 包装器。 Java 库使用 SWIG 生成的类型,例如 com.jphysx.SWIGTYPE_p_NxStre
有没有办法动态向下转换 swig 对象的 swig 代理? 这样做的原因是为了模拟 C++ 向下转换,但纯粹来自 python。例如,典型的 C++ 用法是 MyBase* obj = new MyB
我在远程服务器上工作,所以我在本地安装了 swig,使用 -prefix=/home/user/directory。 我有一个来自同事的 makefile,其中包含以下命令: swig $(SWIG_
据我所知,在用于将 c++ 文件编译为 python 扩展模块的 .i 文件中,我们可以添加一些 python 代码,如下所示(来自 example for adding additional pyt
我的 Swig 文件 (.i) 中有以下代码: %extend vgSofa::handler::VertexShape { vgd::Shp createVSWithNode( so
我有一个用 swig 包装的类的 C++ 代码。我无法修改代码或包装。在 python 中,我使用 ctypes 拥有一个指向所述 C++ 类的实例的指针。如何围绕该指针创建一个 swig 包装器?
我开始掌握 SWIG 的窍门,SWIG 的最新版本 (v3.0) 似乎可以处理我开箱即用所需的一切,包括 C++11 功能,但我遇到了麻烦开始在我的导演类(class)中使用 shared_ptr。
我正在使用 javacode 类型映射来添加一些附加函数来代替 SWIG 生成的函数。我想删除 SWIG 为 unsigned char mac[6]; 生成的默认 getter 和 setter(p
我正在使用 SWIG 为我的 C 库生成 Python 语言绑定(bind)。我已经设法构建了绑定(bind)和导出的数据结构,但在使用该库时我不得不跳过一些障碍。 例如,C 头文件的数据类型和函数原
我最近在node-js应用程序中从jade模板引擎切换到了swig。在使用jade时我使用了命令 jade.render('/sample.jade',{obj:object});渲染模板并传递对象。
我在我的 python 代码中发现了瓶颈,尝试了 Psycho 等。然后决定编写一个 c/c++ 扩展来提高性能。 在 swig 的帮助下,您几乎不需要关心参数等。一切正常。 现在我的问题是:swig
由于 SWIG 无法解析 __attribute__((packed))在我想包装的一些 C 结构上,我通过放置一个 #define __attribute__(x) 在我的.i文件。 这什么时候会来
我有一个包含 C++ header 的 SWIG 文件。 痛饮文件: %module my_module %{ #include "my_c_file.h" %} %include "my_c_fil
我正在尝试学习如何使用 SWIG,并且想知道我是否正在执行一些不需要执行的额外步骤。我目前有文件 Dog.cpp、Dog.h 和 Dog.i。我正在尝试使用 SWIG 包装 Dog.cpp 以便在 P
我是一名优秀的程序员,十分优秀!