- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
首先,对于任何交叉发布,我们深表歉意。希望我没有在这里重复一个问题,但我无法在其他地方找到它(通过 Google 和 Stack Overflow)。
这是错误的要点。如果我在代码中的任何位置调用 printf
、sprintf
或 fprintf
来显示 float ,我会得到一个 SIGSEGV (EXC_BAD_ACCESS)
错误。让我举个例子。
以下抛出错误:
float f = 0.5f;
printf("%f\n",f);
这段代码不会:
float f = 0.5f;
printf("%d\n",f);
我知道那里有一个隐式转换,但我不关心那个。我只是不明白为什么打印 float 与打印整数会引发错误。
注意:部分代码使用malloc
来创建一些非常大的多维数组。但是,对于这些打印语句,这些数组不会以任何方式被引用。下面是我如何声明这些数组的示例。
#define X_LEN 20
#define XDOT_LEN 20
#define THETA_LEN 20
#define THETADOT_LEN 20
#define NUM_STATES (X_LEN+1) * (XDOT_LEN+1) * (THETA_LEN+1) * (THETADOT_LEN+1)
#define NUM_ACTS 100
float *states = (float *)malloc(NUM_STATES * sizeof(float));
// as opposed to float states[NUM_STATES] (more memory effecient)
float **q = (float**)malloc(NUM_STATES * sizeof(float*));
for(int i=0; i < NUM_STATES; i++) {
float *a = (float*)malloc(NUM_ACTS * sizeof(float));
for(int j=0; j < NUM_ACTS; j++) {
a[j] = 0.0f;
}
q[i] = a;
}
然后上面的 printf
语句出现在代码的后面。
我包含 malloc
内容的原因是因为据我了解,SIGSEGV
与格式不正确的 malloc
调用有关。所以,如果数组初始化是导致问题的原因,我想知道:
malloc
代码来解决这个问题?我已经包含了 OS X 生成的崩溃日志,以防万一帮助到任何人。
Process: pole [5453]Path: {REDACTED}Identifier: poleVersion: ??? (???)Code Type: X86-64 (Native)Parent Process: bash [5441]Date/Time: 2009-12-08 11:38:38.358 -0600OS Version: Mac OS X 10.6.2 (10C540)Report Version: 6Interval Since Last Report: 130074 secCrashes Since Last Report: 68Per-App Crashes Since Last Report: 63Anonymous UUID: CA20CF15-8C46-4C85-A793-6C69F9F40140Exception Type: EXC_BAD_ACCESS (SIGSEGV)Exception Codes: KERN_INVALID_ADDRESS at 0x0000000100074f3bCrashed Thread: 0 Dispatch queue: com.apple.main-threadThread 0 Crashed: Dispatch queue: com.apple.main-thread0 libSystem.B.dylib 0x00007fff828d489e __Balloc_D2A + 1641 libSystem.B.dylib 0x00007fff828d49b8 __d2b_D2A + 452 libSystem.B.dylib 0x00007fff828e8c74 __dtoa + 3203 libSystem.B.dylib 0x00007fff828aa960 __vfprintf + 49804 libSystem.B.dylib 0x00007fff828ec7db vfprintf_l + 1115 libSystem.B.dylib 0x00007fff828ec75e fprintf + 1966 pole 0x00000001000028b5 Balance::sarsa() + 1877 pole 0x0000000100002e54 main + 498 pole 0x00000001000010a8 start + 52Thread 0 crashed with X86 Thread State (64-bit): rax: 0x0000000000000001 rbx: 0x000000010042cca0 rcx: 0x000000010042cca8 rdx: 0x0000000100074f3b rdi: 0x000000000000000e rsi: 0x00007fff5fbfecbc rbp: 0x00007fff5fbfeba0 rsp: 0x00007fff5fbfeb90 r8: 0x00007fff5fbff0b0 r9: 0x0000000000000000 r10: 0x00000000ffffffff r11: 0x000000010083a40b r12: 0x0000000000000001 r13: 0x00007fff5fbfecb8 r14: 0x00007fff5fbfecbc r15: 0x000000010000363e rip: 0x00007fff828d489e rfl: 0x0000000000010202 cr2: 0x0000000100074f3bBinary Images: 0x100000000 - 0x100003fff +pole ??? (???) {REDACTED} 0x7fff5fc00000 - 0x7fff5fc3bdef dyld 132.1 (???) /usr/lib/dyld 0x7fff81697000 - 0x7fff8169bff7 libmathCommon.A.dylib ??? (???) /usr/lib/system/libmathCommon.A.dylib 0x7fff8289c000 - 0x7fff82a5aff7 libSystem.B.dylib ??? (???) /usr/lib/libSystem.B.dylib 0x7fff83c4c000 - 0x7fff83cc9fef libstdc++.6.dylib ??? (???) /usr/lib/libstdc++.6.dylib 0x7fffffe00000 - 0x7fffffe01fff libSystem.B.dylib ??? (???) /usr/lib/libSystem.B.dylibModel: MacBookPro4,1, BootROM MBP41.00C1.B03, 2 processors, Intel Core 2 Duo, 2.4 GHz, 2 GB, SMC 1.27f2Graphics: NVIDIA GeForce 8600M GT, GeForce 8600M GT, PCIe, 256 MBMemory Module: global_nameAirPort: spairport_wireless_card_type_airport_extreme (0x14E4, 0x8C), Broadcom BCM43xx 1.0 (5.10.91.19)Bluetooth: Version 2.2.4f3, 2 service, 1 devices, 1 incoming serial portsNetwork Service: AirPort, AirPort, en1Serial ATA Device: Hitachi HTS542520K9SA00, 186.31 GBParallel ATA Device: MATSHITADVD-R UJ-867USB Device: Built-in iSight, 0x05ac (Apple Inc.), 0x8502, 0xfd400000USB Device: Apple Internal Keyboard / Trackpad, 0x05ac (Apple Inc.), 0x0230, 0x5d200000USB Device: IR Receiver, 0x05ac (Apple Inc.), 0x8242, 0x5d100000USB Device: BRCM2046 Hub, 0x0a5c (Broadcom Corp.), 0x4500, 0x1a100000USB Device: Bluetooth USB Host Controller, 0x05ac (Apple Inc.), 0x820f, 0x1a110000
谢谢。
最佳答案
您的代码中存在与 printf
语句无关的错误。你在某处占用内存,但问题并没有显现出来,直到 printf
尝试使用 __BAlloc_D2A
分配一些内存,它崩溃了,因为它使用的堆数据结构跟踪已损坏的空闲内存块。
要尝试检测您在何处占用内存,可以使用多种工具。如果您使用的是 Linux,我建议您使用 valgrind ,它本质上是在虚拟机中运行您的代码,并在您执行任何非法操作时告诉您,例如越界读/写内存、读取未初始化的变量等。但是,它在 Mac OS X 中不可用(目前)。
一种选择是使用 libgmalloc :
% cat gmalloctest.c
#include <stdlib.h>
#include <stdio.h>
main()
{
unsigned *buffer = (unsigned *)malloc(sizeof(unsigned) * 100);
unsigned i;
for (i = 0; i < 200; i++) {
buffer[i] = i;
}
for (i = 0; i < 200; i++) {
printf ("%d ", buffer[i]);
}
}
% cc -g -o gmalloctest gmalloctest.c
% gdb gmalloctest
Reading symbols for shared libraries .. done
(gdb) set env DYLD_INSERT_LIBRARIES /usr/lib/libgmalloc.dylib
(gdb) r
Starting program: gmalloctest
Reading symbols for shared libraries .. done
GuardMalloc: Allocations will be placed on 16 byte boundaries.
GuardMalloc: - Some buffer overruns may not be noticed.
GuardMalloc: - Applications using vector instructions (e.g., SSE or Altivec) should work.
GuardMalloc: GuardMalloc version 19
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_PROTECTION_FAILURE at address: 0xb000d000
0x00001f65 in main () at gmalloctest.c:10
10 buffer[i] = i;
(gdb) print i
$1 = 100
(gdb) where
#0 0x00001f65 in main () at gmalloctest.c:10
(gdb)
关于c - SIGSEGV,(貌似)由 printf 引起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1868719/
我有一个问题,在我启动应用程序后,偶尔(即并非总是)看到以下错误消息从Debug Flash Player中弹出: Error #2044: Unhandled securityError:. tex
我正在为 Flask 编写注册/登录脚本,我正在使用 flask-sqlalchemy。为了注册用户,我通过 flask-sqlalchemy 将他们的详细信息插入到数据库中,然后提交更改。但是,当他
首先,对于任何交叉发布,我们深表歉意。希望我没有在这里重复一个问题,但我无法在其他地方找到它(通过 Google 和 Stack Overflow)。 这是错误的要点。如果我在代码中的任何位置调用 p
我注意到 Maven 输出报告的插件版本号与我在 pom 文件中指定的版本号不同。 例如,在我的pom中我指定编译器插件版本为3.1 org.apache.maven.plugins mav
我正在学习 C 语言并了解指针。据我了解,当您声明一个数组时,该数组的地址是该数组中第一个元素的地址。所有其他元素都连续存储在内存中。 当我使用 online C compiler at online
我正在学习 C 语言并了解指针。据我了解,当您声明一个数组时,该数组的地址是该数组中第一个元素的地址。所有其他元素都连续存储在内存中。 当我使用 online C compiler at online
我是一名优秀的程序员,十分优秀!