- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
<分区>
我正在为我的网络类(class)做一个小组项目。我们将实现一个由 3 个部分组成的 key 分发中心; KDC 本身,一个发起者 (A) 和一个响应者 (B) 在大学拥有的 RedHat 6 服务器上使用 c++ 和 g++。
我们一直在使用这个 Practical Sockets图书馆和事情进展得比较顺利。
我和我的搭档在调用 Unix 的 gethostbyname() 函数时开始出现段错误,特别是在 fillAddr() function 中。 .
// Function to fill in address structure given an address and port
static void fillAddr(const string &address, unsigned short port,
sockaddr_in &addr) {
memset(&addr, 0, sizeof(addr)); // Zero out address structure
addr.sin_family = AF_INET; // Internet address
hostent *host; // Resolve name
if ((host = gethostbyname(address.c_str())) == NULL) { /* offending line */
// strerror() will not work for gethostbyname() and hstrerror()
// is supposedly obsolete
throw SocketException("Failed to resolve name (gethostbyname())");
}
addr.sin_addr.s_addr = *((unsigned long *) host->h_addr_list[0]);
addr.sin_port = htons(port); // Assign port in network byte order
}
我们使用了 valgrind、GDB、“cout s”等进行调试,但一直取得负面进展。以下是 GDB 回溯告诉我们的内容(服务器名称经过审查,使用了典型的“server.college.edu”地址):
Program received signal SIGSEGV, Segmentation fault.
0x00000039b1a7621b in malloc_consolidate () from /lib64/libc.so.6
Missing separate debuginfos, use: debuginfo-install glibc-2.12-1.107.el6.x86_64 libgcc-4.4.7-3.el6.x86_64 libstdc++-4.4.7-3.el6.x86_64
(gdb) backtrace
#0 0x00000039b1a7621b in malloc_consolidate () from /lib64/libc.so.6
#1 0x00000039b1a79385 in _int_malloc () from /lib64/libc.so.6
#2 0x00000039b1a7a911 in malloc () from /lib64/libc.so.6
#3 0x00000039b1b03265 in gethostbyname () from /lib64/libc.so.6
#4 0x00000000004033f7 in fillAddr (address="KDC", port=9284, addr=...)
at PracticalSocket.cpp:72
#5 0x0000000000404484 in UDPSocket::sendTo (this=0x7fffffffe410, buffer=0x6102a0, bufferLen=40, foreignAddress=
"KDC", foreignPort=9284) at PracticalSocket.cpp:299
#6 0x00000000004085e2 in sendRecv (sock=..., message="2007|137.28.8.164|SERVER_B|1234", addr=
"KDC", port=9284) at initiator.cpp:144
#7 0x0000000000407a3f in getSessionKey (sock=..., kdc_addr=0x40aa84 "KDC",
resp_addr=0x40aa98 "RESPONDER", nonce="1234") at initiator.cpp:88
#8 0x0000000000407546 in main (argc=1, argv=0x7fffffffe548) at initiator.cpp:49
似乎我们编译、测试、调试等的次数越多,只有一些小的改变,比如额外的 std::cout 等等,我们的代码执行得越少。这个 fillAddr() 函数被成功地使用了好几次,至少一开始是这样。现在将可靠地由 malloc_consolidate() 引起的段错误。
以下是目前的情况:
*** glibc detected *** ./kdc: malloc(): memory corruption: 0x000000000132b7d0 ***
*** glibc detected *** ./kdc: malloc(): memory corruption: 0x000000000132b7d0 ***
...
*** glibc detected *** ./kdc: malloc(): memory corruption: 0x000000000132b7d0 ***
这会填满我们的 KDC 控制台窗口。
任何帮助将不胜感激。如果您想了解更多信息,请告诉我。
当我查看 gdb 中的回溯时,我的应用程序有时会出现段错误,主要出现在 malloc() 和 malloc_consolidate() 中。 我确认机器有足够的可用内存,它甚至没有开始交换。我检查了
这个问题在这里已经有了答案: Segfaults in malloc() and malloc_consolidate() (2 个答案) 关闭 9 年前。 一些背景信息: 我正在为我的网络类(cl
我正在使用以下代码在 ARM 上登录: template MyClass& operator selftid = 1673 res = #1 0x3696
这个问题在这里已经有了答案: Segfaults in malloc() and malloc_consolidate() (2 个回答) 关闭6年前。 我的程序出现段错误,我找不到原因。最糟糕的是,
当 JavaThread“Finalizer”在 JVM 中运行时,生产环境中的 tomcat 服务器经常崩溃,hs_err_pid 在下方。 此外,错误来自 libc.so 中 malloc_con
我是一名优秀的程序员,十分优秀!