我使用此命令编译:
gcc –Werror –std=c99 client.c –o client
CODE:
#include <string.h>
#include <stdio.h>
#include <strings.h>
#include <stdlib.h>
#include <unistd.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#define BUFFER_SIZE 1000
#define PORT_NUM 8888
void error(char *msg)
{
perror(msg);
exit(0);
}
int main(int argc, char *argv[])
{
int sockfd, portno, n;
struct sockaddr_in serv_addr;
struct hostent *server;
char buffer[BUFFER_SIZE];
if (argc < 3) {
fprintf(stderr,"usage %s hostname port\n", argv[0]);
exit(0);
}
portno = atoi(argv[2]);
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket");
server = gethostbyname(argv[1]);
if (server == NULL) {
fprintf(stderr,"ERROR, no such host\n");
exit(0);
}
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr,
(char *)&serv_addr.sin_addr.s_addr,
server->h_length);
serv_addr.sin_port = htons(portno);
if (connect(sockfd,(struct sockaddr *)&serv_addr,sizeof(serv_addr)) < 0)
error("ERROR connecting");
while (1)
{
bzero(buffer, BUFFER_SIZE);
fgets(buffer, BUFFER_SIZE, stdin);
if((strncmp(buffer,"close",5) == 0 ))
break;
printf("Please enter the message: ");
bzero(buffer, BUFFER_SIZE);
n = write(sockfd,buffer,strlen(buffer));
if (n < 0)
error("ERROR writing to socket");
bzero(buffer, BUFFER_SIZE);
n = read(sockfd,buffer, BUFFER_SIZE-1);
if (n < 0)
error("ERROR reading from socket");
printf("%s\n",buffer);
}
close(sockfd);
return 0;
}
尝试在操作系统为Linux的VM上编译它 这个错误让我发疯,我不明白该做什么来解决这个问题。 我认为client.c文件已损坏,因此我复制并粘贴到新的.c文件中。当失败时,我从0开始编写它并仍然出现此错误。
提前致谢!
答案 0 :(得分:2)
在结束括号后面添加回车(新行)。
答案 1 :(得分:2)
文本处理程序并不总是同意\n
字符是行分隔符还是行终止符 - 不同之处在于最后一行是否在文件中应该跟一个\n
字符后跟。
我从未见过GCC抱怨这一点,但你没有说明错误的实际来源。
您应该只需在文件的最后一行后按ENTER即可纠正这种情况。
或者,您可以打开,并使用像Vim这样的编辑器保存文件,该编辑器将其视为行终结符。
作为比较,大多数UNIX工具还将\n
视为行终止符,并在最后一行之后包含它。这允许一个cat
文件而不会破坏后面的任何内容(例如另一个文件,shell提示符等)