Linux n00b這裏。大約一個月前,我安裝了emacs和gcc/g ++編譯器,並開始編程。我在網上找到了一些echo服務器程序的代碼,將它複製並編譯成測試網絡功能。它編譯,但後來當我試圖運行它,我得到了錯誤信息:分段錯誤(核心轉儲)。當我仔細查看調試器的詳細信息時,這是「fwrite()」函數中的錯誤。我在編譯和創建輸出文件時將代碼鏈接到了庫文件libstdC++。a,因此它確實讓我懷疑實際庫函數中是否存在某些嚴重錯誤,並且需要返回找到.c源代碼函數,然後將它們添加到標題以使其工作。該代碼發佈如下。任何人都有這個問題?Linux套接字:分割錯誤
#include <sys-socket.h> /* socket definitions */
#include <sys-types.h> /* socket types */
#include <netinet-in.h> /* inet (3) functions */
#include <unistd.h> /* misc. UNIX functions */
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <ether.h>
#include <string.h>
/* Global constants */
#define ECHO_PORT 2002
#define MAX_LINE 1000
#define LISTENQ 5
ssize_t Readline(int sockd, char *vptr,size_t maxlen) {
ssize_t n, rc;
char* c;
msghdr* buffer;
buffer->msg_iov->iov_base = vptr;
buffer->msg_iov->iov_len = maxlen;
for (n = 1; n < maxlen; n++) {
if ((rc = recvmsg(sockd,buffer, 1)) == 1) {
c = buffer->msg_iov->iov_base++;
if (*c == '\n')
break;
}
else if (rc == 0) {
if (n == 1)
return 0;
else
break;
}
else {
if (rc < 0)
continue;
return -1;
}
}
buffer->msg_iov->iov_base = 0;
return n;
}
/* Write a line to a socket */
ssize_t Writeline(int sockd, char *vptr) {
msghdr *buffer;
buffer->msg_iov->iov_base = vptr;
size_t nleft = buffer->msg_iov->iov_len;
ssize_t nwritten;
while (nleft > 0) {
if ((nwritten = sendmsg(sockd, buffer, nleft)) < 0) {
return -1;
}
nleft -= nwritten;
buffer += nwritten;
}
return nwritten;
}
int main(int argc, char *argv[]) {
int list_s; /* listening socket */
int conn_s; /* connection socket */
short int port; /* port number */
struct sockaddr_in servaddr; /* socket address structure */
char *endptr; /* for strtol() */
char buffer[MAX_LINE];
port = 5000;
/* Create the listening socket */
if ((list_s = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
fprintf(stderr, "ECHOSERV: Error creating listening socket.\n");
exit(EXIT_FAILURE);
}
/* Set all bytes in socket address structure to
zero, and fill in the relevant data members */
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
servaddr.sin_port = htons(port);
/* Bind our socket addresss to the
listening socket, and call listen() */
if (bind(list_s, (struct sockaddr *) &servaddr, sizeof(servaddr)) < 0) {
fprintf(stderr, "ECHOSERV: Error calling bind()\n");
exit(EXIT_FAILURE);
}
if (listen(list_s, LISTENQ) < 0) {
fprintf(stderr, "ECHOSERV: Error calling listen()\n");
exit(EXIT_FAILURE);
}
/* Enter an infinite loop to respond
to client requests and echo input */
while (1) {
/* Wait for a connection, then accept() it */
if ((conn_s = accept(list_s, NULL, NULL)) < 0) {
fprintf(stderr, "ECHOSERV: Error calling accept()\n");
exit(EXIT_FAILURE);
}
/* Retrieve an input line from the connected socket
then simply write it back to the same socket. */
Readline(conn_s, buffer, MAX_LINE-1);
Writeline(conn_s, buffer);
/* Close the connected socket */
if (shutdown(conn_s,0) < 0) {
fprintf(stderr, "ECHOSERV: Error calling close()\n");
exit(EXIT_FAILURE);
}
}
}
你可以發佈完整的堆棧跟蹤嗎? – bennofs
以下是來自調試器的更多詳細信息:*段錯誤發生在0x7f6302d53c04:mov(%rcx),%eax PC(0x7f6302d53c04)OK源(「%rcx)」未位於已知VMA區域(需要可讀區域! 「%eax」ok *所以這看起來像是操作數大小衝突,但fwrite()函數在哪裏實現?我沒有寫這個代碼來介意你。 –
@bennofs:它說「沒有stacktrace可用」,所以不幸我不能。函數「fwrite()」作爲原型在標題中。所以這似乎是問題所在。但我不知道如何解決它。 –