在套接字上通信时出现分段错误:大小为1的写入无效

时间:2013-11-10 02:40:55

标签: c++ sockets pointers valgrind

我是C ++的初学者。我之前用解释语言编写过代码。

我正在用C ++编写客户端服务器代码,使用套接字编程来执行一些文件操作。客户端将文件名发送到服务器,服务器打开该文件以执行操作。

以下代码段显示了从客户端接受文件名的过程:

char buf[512];
char *name;
connectionID = accept(socketID, (sockaddr *) NULL, NULL);
cout << "Connection created" << endl;
int bytes = recv(connectionID, buf, sizeof(buf), 0);
buf[bytes] = '\0';
strcpy(name, buf);
cout << name << endl;

此代码随机工作。我将它移植到另一个文件,它突然停止工作。 当我尝试使用GDB查看分段错误发生的位置时,GDB显示空行或代码中的任何行,似乎无关紧要。

>(gdb) where
>#0  0xb74a8979 in ?? ()
>#1  0x00000000 in ?? ()
>(gdb) up
>#1  0x00000000 in ?? ()
>(gdb) down
>#0  0xb74a8979 in ?? ()
>(gdb) down
>Bottom (innermost) frame selected; you cannot go down.

但是,valgrind输出显示了一些信息,但我仍然无法弄清楚这里有什么问题。

>==11855== Invalid write of size 1
>==11855==    at 0x402C6C3: strcpy (in /usr/lib/valgrind/vgpreload_memcheck-x86-    linux.so)
>==11855==    by 0x804D38A: main (server.cpp:100)
>==11855==  Address 0x0 is not stack'd, malloc'd or (recently) free'd
>==11855== 
>==11855== 
>==11855== Process terminating with default action of signal 11 (SIGSEGV)
>==11855==  Access not within mapped region at address 0x0
>==11855==    at 0x402C6C3: strcpy (in /usr/lib/valgrind/vgpreload_memcheck-x86-l

Valgrind也表现出

>==11871== Use of uninitialised value of size 4
>==11871==    at 0x402C6C3: strcpy (in /usr/lib/valgrind/vgpreload_memcheck-x86-    linux.so)
>==11871==    by 0x8048DF8: main (in /media/sf_programs/project/a.out)

但是,如果我将名称指针初始化为NULL,则不会发生此错误。然后,只有无效的写入大小的发生者。

我看到了无效写入大小的帖子,其中,当指针在范围之外被访问时会发生seg错误。但我无法弄清楚它在哪里超出范围。

您有任何有用的信息吗?程序似乎在接收字符串输入并从客户端存储它时崩溃。

1 个答案:

答案 0 :(得分:1)

char *name;

你做了一个指针,太好了,但是你忘了把它指向任何东西。例如,像内存缓冲区。

不要在这里看到特定的 valgrind 诊断;他们都在同一个主题上:你试图使用不属于你的完全随机的记忆。

无论您是将name初始化为NULL还是将其保留为未初始化或喂它奶油奶酪,都是如此。在你给它分配你拥有的有效记忆的位置之前,你不妨在Titantic的甲板上唱Macarena,因为这艘船可能会在一些场景中浮动一点(只有足够的时间用于一些戏剧性的电影院),但是,从长远来看,它不会再起航了!