Поэтому я использую python для вызова методов в общей библиотеке C ++. У меня проблема с возвратом двойного числа из C ++ в python. У меня есть созданный игрушечный пример, который демонстрирует проблему. Не стесняйтесь компилировать и попробовать это.
Вот код Python (soexample.py):
# Python imports
from ctypes import CDLL
import numpy as np
# Open shared CPP library:
cpplib=CDLL('./libsoexample.so')
cppobj = cpplib.CPPClass_py()
# Stuck on converting to short**?
x = cpplib.func_py(cppobj)
print 'x =', x
Вот C ++ (soexample.cpp):
#include <iostream>
using namespace std;
class CPPClass
{
public:
CPPClass(){}
void func(double& x)
{
x = 1.0;
}
};
// For use with python:
extern "C" {
CPPClass* CPPClass_py(){ return new CPPClass(); }
double func_py(CPPClass* myClass)
{
double x;
myClass->func(x);
return x;
}
}
Компилировать с:
g++ -fPIC -Wall -Wextra -shared -o libsoexample.so soexample.cpp
Когда я бегу, я получаю:
$ python soexample.py
x = 0
Таким образом, результатом является целое число типа и значения 0. Что происходит?
Мне также любопытно заполнить массивы по ссылке.
По умолчанию предполагается, что функции возвращают C
int
тип. Другой
Типы возвращаемых данных можно указать, установивrestype
атрибут
функциональный объект.
Это работает, если вы измените свое использование func_py
к следующему:
import ctypes
func_py = cpplib.func_py
func_py.restype = ctypes.c_double
x = func_py(cppobj)
print 'x =', x
Хотя это, вероятно, будет работать для этого простого случая, вы должны также указать CPPClass_py.restype
также.
Других решений пока нет …