突然从cython重复调用c++方法要慢得多

repeatedly calling a c++ method from cython suddenly is much slower

本文关键字:方法 c++ 调用 cython 突然      更新时间:2023-10-16

我经常使用cython包装c++类。所有的计算都是在c++中完成的,cython只用于将变量传递给构造函数并从c++中获得结果。

对于最近的一个项目,我遇到了以下问题:代码(初始化一个类,然后调用一个方法)最初总是运行良好,但在重复调用同一个方法后(我无法准确再现),在调用同一方法时,它的运行速度突然比正常情况慢了至少1000倍。

我的问题是:是什么导致了这种看似随机的行为,你会如何调试它?

我知道如果没有看到代码,这是不可能解决的,但它很大,我不知道问题行为来自哪里。我只是想了解如何解决这个问题的提示和策略

我尝试过的东西:

  • 已检查c++代码是否存在泄漏
  • 尝试了不同的编译器指令(#cython:wrappearound=False,boundcheck=False,…)

一个提示可能是,如果我在没有ipython的--pylab选项的情况下运行python代码,它会抱怨找不到符号,但这是我能够识别的唯一问题。

它是一个未初始化的成员,偶尔会导致问题,而不是内存泄漏。感谢那些试图提供帮助的人!

ipython的问题仍然存在,但我在另一个问题中发布了这个问题。