如何解决arrow::py::import_pyarrow() 导致 SEGMENTATION FAULT CMakeLists.txtcpp 文件输出调试模式
我正在尝试使用 arrow-cpp 构建一个表,然后将其传输回 python。
为了做到这一点,我需要事先调用 arrow::py::import_pyarrow(),但这会导致一个 SEGFAULT。
谁能帮忙找出我做错的地方?
这是一个最小的例子
CMakeLists.txt
cmake_minimum_required(VERSION 3.20.0)
project(TEST)
set(CMAKE_CXX_STANDARD 17)
set(python3_EXECUTABLE "/home/auderson/miniconda3/bin/python3.8")
list(APPEND CMAKE_PREFIX_PATH "/home/auderson/miniconda3/lib/cmake/arrow")
find_package(Arrow required)
find_package(ArrowPython required)
find_package(python3 COMPONENTS Interpreter Development)
include_directories(.
/home/auderson/miniconda3/lib/python3.8/site-packages/pyarrow/include
${python3_INCLUDE_Dirs})
add_executable(TEST
mini_t.cpp
)
target_link_libraries(${PROJECT_NAME} PRIVATE arrow_shared)
target_link_libraries(${PROJECT_NAME} PRIVATE arrow_python_shared)
target_link_libraries(${PROJECT_NAME} PRIVATE ${python3_LIBRARIES})
cpp 文件
#include "arrow/python/pyarrow.h"
int main() {
return arrow::py::import_pyarrow();
}
输出(调试模式)
Signal: SIGSEGV (Segmentation fault)
Process finished with exit code 1
如果不是在调试模式:
Process finished with exit code 139
箭头的其他功能工作正常。
解决方法
C++ 应用程序不会初始化 Python 解释器。这是一个正确执行此操作的示例 C++ 可执行文件:
这也在
上得到了回答版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。