我在ubuntu 12.04上,使用uname -a: Linux lu057801 3.2.0-31-generic#50-Ubuntu SMP Fri Sep 7 16:16:45 UTC 2012 x86_64 x86_64 x86_64 GNU / Linux
g ++ --version: Linux lu057801 3.2.0-31-generic#50-Ubuntu SMP Fri Sep 7 16:16:45 UTC 2012 x86_64 x86_64 x86_64 GNU / Linux
我在调用vsnprintf时获得了核心转储。以下是产生问题的完整代码:
// compile: g++ -g -o test vsnprintf_test.c
#include <stdarg.h>
#include <stdio.h>
#include <string>
void vout(char *string, char *fmt, ...);
char fmt1 [] = "%s %s %s\n";
size_t snprintf_1(char* buffer, const size_t bufSize, const char* format, ...);
size_t vsnprintf_1(char* buffer, const size_t bufSize, const char* format, va_list args);
int main(void)
{
char * format = "%s";
char buffer[] = "/var/tmp\0"; //char * buffer = "/var/tmp\0";
int bufSize=sizeof(buffer); //int bufSize=11;
snprintf_1(buffer, bufSize, format);
}
size_t snprintf_1(char* buffer, const size_t bufSize, const char* format, ...)
{
va_list args;
va_start(args, format);
size_t rc = vsnprintf_1(buffer, bufSize, format, args);
va_end(args);
return rc;
}
size_t vsnprintf_1(char* buffer, const size_t bufSize, const char* format, va_list args)
{
int rc = 0;
rc = vsnprintf(buffer, bufSize, format, args);
}
编译为:g ++ -g -o test vsnprintf_test.c并且运行会给我以下回溯:
(gdb) run
Starting program: /home/mafunk/software/MattsSnippets/test
Program received signal SIGSEGV, Segmentation fault.
_IO_vsnprintf (string=0x400738 "/var/tmp", maxlen=<optimized out>, format=0x400730 "%s", args=0x7fffffffe0b0) at vsnprintf.c:118
118 vsnprintf.c: No such file or directory.
(gdb) bt
#0 _IO_vsnprintf (string=0x40072f "/var/tmp", maxlen=<optimized out>, format=0x40072c "%s", args=0x7fffffffe0b0) at vsnprintf.c:118
#1 0x0000000000400639 in vsnprintf_1 (buffer=0x40072f "/var/tmp", bufSize=11, format=0x40072c "%s", args=0x7fffffffe0b0)
at vsnprintf_test.c:36
#2 0x00000000004005f2 in snprintf_1 (buffer=0x40072f "/var/tmp", bufSize=11, format=0x40072c "%s") at vsnprintf_test.c:27
#3 0x0000000000400541 in main () at vsnprintf_test.c:19
我想我不确定为什么会这样。任何帮助将不胜感激。
答案 0 :(得分:3)
您正在修改字符串文字,这是未定义的行为。更改为此可能会有效(尽管您的缓冲区看起来对我来说仍然太小)。
char buffer[] = "/var/tmp\0";
在此代码中,buffer
是一个数组,而不是指向字符串文字的指针。
答案 1 :(得分:3)
导致段错误是因为您尝试写入的目标是字符串文字。
此外,调用snprintf_1(buffer, bufSize, format);
传递"%s"
格式字符串,但没有其他参数。格式字符串需要一个额外的char *
参数,代码将在调用堆栈中读取您未提供的字符串指针的随机内存。
答案 2 :(得分:1)
你的缓冲区太小了
char * buffer = "/"/var/tmp/.SHM_SAP_IPMM_0008_no-sid\0"; **//37 char**
int bufSize=**35**;