- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在 Windows XP 上使用 Python 2.7。
我有一个简单的 python 脚本,它使用 pyodbc 从 AR 数据库中获取数据,直到今天它一直运行良好。一旦光标到达特定行,我就会收到段错误。我在 C++ 中有类似的代码,检索结果没有问题,所以我认为这是 pyodbc 的问题。无论哪种方式,我都想“捕获”这个错误。我试过使用 subprocess 模块,但它似乎不起作用,因为一旦脚本遇到段错误,它就会卡在“python.exe 遇到问题需要关闭”上。信息。我想我可以为它设置一些任意的时间框架来完成,如果没有,则强制关闭该过程,但这似乎有些蹩脚。
我也在这里报告了这个问题 - http://code.google.com/p/pyodbc/issues/detail?id=278
@paulsm4 - 我已经在下面回答了你的问题,谢谢!
Q: You're on Windows/XP (32-bit, I imagine), Python 2.7, and BMC Remedy AR. Correct?
答:是的,它在 Win XP 32 位和 Win Server 2008 R2 64 位上失败。
Q: Is there any chance you (or perhaps your client, if they purchased Remedy AR) can open a support call with BMC?
答:应该不会吧
Q: Can you isolate which column causes the segfault? "What's different" when the segfault occurs?
答:只是这一行……但我现在已经将问题与您在下面的建议隔离开来。我使用循环来获取每个字段,直到发生段错误。
cursor.columns(table="mytable")
result = cursor.fetchall()
columns = [x[3] for x in result]
for x in columns:
print x
cursor.execute("""select "{0}"
from "mytable"
where id = 'abc123'""".format(x))
cursor.fetchall()
一旦我确定了导致段错误的列,我就尝试查询除该列之外的所有列,果然它没有问题。
该列的数据类型为 CHAR(1024)。我使用 C++ 来抓取数据,并注意到该行的列中的字符最多......1023!认为 PyODBC 的 C 代码中可能有一个缓冲区被写入超出其边界。
2) Enable ODBC tracing: http://support.microsoft.com/kb/274551
3) Post back the results (including the log trace of the failure)
好的,我已经用 ODBC 跟踪的结果创建了一个 pastebin - http://pastebin.com/6gt95rB8 .为了保护无辜者,我屏蔽了一些字符串值。
看起来可能是由于数据截断造成的。
这是否为我们提供了有关如何解决问题的足够信息?我认为这是 PyODBC 中的一个错误,因为直接使用 C ODBC API 可以正常工作。
更新
所以我编译了 PyODBC 进行调试,我得到了一条有趣的消息 -
Run-Time Check Failure #2 - Stack around the variable 'tempBuffer' was corrupted.
虽然暂时看不懂,调用栈如下——
pyodbc.pyd!GetDataString(Cursor * cur=0x00e47100, int iCol=0) Line 410 + 0xf bytes C++
pyodbc.pyd!GetData(Cursor * cur=0x00e47100, int iCol=0) Line 697 + 0xd bytes C++
pyodbc.pyd!Cursor_fetch(Cursor * cur=0x00e47100) Line 1032 + 0xd bytes C++
pyodbc.pyd!Cursor_fetchlist(Cursor * cur=0x00e47100, int max=-1) Line 1063 + 0x9 bytes C++
pyodbc.pyd!Cursor_fetchall(_object * self=0x00e47100, _object * args=0x00000000) Line 1142 + 0xb bytes C++
已解决!
通过确保缓冲区有足够的空间来解决问题。
在 getdata.cpp
的第 330 行
char tempBuffer[1024];
已更改为
char tempBuffer[1025];
编译并替换站点包中的旧 pyodbc.pyd 文件,我们都很好!
感谢您的帮助!
最佳答案
问:您使用的是 Windows/XP(我想是 32 位),Python 2.7 , 和 BMC Remedy AR .正确吗?
问:您(或者您的客户,如果他们购买了 Remedy AR)是否有机会向 BMC 调用支持电话?
问:你能找出导致段错误的列吗?发生段错误时“有什么不同”?
请执行以下操作:
1) 使用 Python/ODBC 尝试不同的“select a,b,c”语句,看看您是否可以重现问题(独立于您的程序)并隔离特定列(或者,理想情况下,特定列和行! )
2) 启用 ODBC 跟踪: http://support.microsoft.com/kb/274551
3) 回传结果(包括失败的日志跟踪)
4) 如果这不起作用 - 如果您不能让 BMC 技术支持参与进来 - 那么计划 B 可能是在 ODBC 库级别进行调试:
How to debug C extensions for Python on Windows
问:哪种 C/C++ 编译器最适合您?
关于python - PyODBC Cursor.fetchall() 导致 python 崩溃(segfault),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11657958/
所以我需要一个简单的分配器来分配(有时使用清零)并随后从映射内存池中释放 4K block 。然而,在实现这个之后,在测试时我发现在释放一两个 block 之后,如果我尝试分配一个 block ,程序
我的任务是用 C 编写一个程序。该程序应该能够检查参数并创建与我提供的参数一样大的数组。我必须用随机数填充数组。到目前为止工作正常。稍后我的任务是使用指针对数组进行排序。第一件事是我不太明白指针是如何
我对 C 很陌生(仍然)所以如果我误解了一些基本的东西,请耐心等待 我有一个简单的程序,它应该将文件作为字符串读取,然后将该字符串拆分成行 - 将结果存储到 n 个字符串数组中。但是,当我运行以下代码
我在工作中使用的应用程序之一遇到了一个奇怪且烦人的问题。该应用程序是用 C++ 编写的,当应用程序终止(主函数返回或调用 exit)时,它会因段错误而崩溃。段错误似乎是由 basic_string 类
我使用 python swig 包装的 C++ 库。在它的 __init__.py 文件中,它 sets在导入包含实现代码的共享对象文件之前,使用 dlopen 标志 RTLD_GLOBAL。 这会导
我在这里遇到了段错误。我很困惑。请帮帮我。 f1 和 y 都是结构体节点的指针。我想把 y 的左转 f1 右转。 #include #include struct node{
我有一个在公共(public)结构中声明的数组,如下所示: uint16_t *registers; 在一个函数中,我正在检索一个字符字符串(存储在缓冲区中,请参阅下面的代码),其中包含以逗号分隔的数
我正在用 C 实现二叉搜索树。下面的代码工作正常,只是当我尝试从树中删除子树时得到 SEGFAULT: 源代码: #include #include struct node { int dat
struct vehicle *add_vehicle(struct vehicle *v){ struct vehicle *newcar = (struct vehicle*)malloc
我正在使用链接列表实现符号表,代码工作正常,但代码中存在内存泄漏, 我有以下结构 struct node { char* pcKey; void* pvValue; struct node
我正在尝试将字符串复制到数组并打印它。它适用于第一个 for 循环,但第二次出现 seg 错误。 main (int argc, char *argv[]){ int argcIndex; cha
自从我用 C 编写代码已经一年了,但我不明白为什么会出现段错误 // Assume all imports are made int printAgain(double** array, int si
这是我的代码。编辑:调用者包含在底部。 该函数读取数据文件,确定有多少行和列,然后将数据存储到 data_array 中。 int getdata(double* *data_array, int*
我认为有两组代码是等效的,但一组会导致段错误,而另一组则不会。我真的很困惑为什么会这样...... 我想创建一个查找函数 此代码确实有效: MyPair *> dummy(x, NULL);
希望有人能提供帮助。我可以毫无错误地编译,我没有发现任何语法错误,但是当我运行它时,它崩溃了。在启动时调试段错误。全面披露,这是作业。我不是要找人来编写这个代码,只是看看我的问题和我现有的代码,也许会
我正在尝试在OpenMP中并行化相当大的for-loop。大约有20%的时间运行正常,但其余时间会因各种段错误而崩溃,例如: *** glibc detected *** ./execute: dou
我有一个模板类 ISingleton class ISingleton { public: static T* getInstance() { lock_guard g
我正在为使用 LibSVM 的 Android 构建 NDK 应用程序。我在 XCode 中为我的 mac 构建了一个等价物(都是 C++) 我发现 Mac 可以高速准确地处理我给它的非常大的特征向量
我在 ARM linux 平台上有一个由简单代码引起的非常奇怪的崩溃。问题是它很少重现(一天一次),另一个问题是它在实际上无法重现的地方崩溃。 让我们从 C++ 代码开始。线程函数执行此操作:
我有这段代码 int main() { int *b = new int(8); cout<<" &b = "<
我是一名优秀的程序员,十分优秀!