我是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错误。但我无法弄清楚它在哪里超出范围。
您有任何有用的信息吗?程序似乎在接收字符串输入并从客户端存储它时崩溃。
答案 0 :(得分:1)
char *name;
你做了一个指针,太好了,但是你忘了把它指向任何东西。例如,像内存缓冲区。
不要在这里看到特定的 valgrind 诊断;他们都在同一个主题上:你试图使用不属于你的完全随机的记忆。
无论您是将name
初始化为NULL
还是将其保留为未初始化或喂它奶油奶酪,都是如此。在你给它分配你拥有的有效记忆的位置之前,你不妨在Titantic的甲板上唱Macarena,因为这艘船可能会在一些场景中浮动一点(只有足够的时间用于一些戏剧性的电影院),但是,从长远来看,它不会再起航了!