我正在使用 select 从用户读取数据并检查传入连接。这是我的代码,
.....
socket has been created and is listening
while(1){
printf("$ ");
fflush(stdout);
read_fds = master;
if(select(fdmax+1, &read_fds, NULL, NULL, NULL) == -1){
perror(" Select failed: ");
exit(-1);
}
for(int i=0; i <= fdmax; i++){
if (FD_ISSET(i, &read_fds)) {
if(i == STDIN){//process user input
char usrInputStr[256];
if ((rbytes = read(STDIN, usrInputStr, 256)) < 0) {
perror("Read error: ");
exit(-1);
}
fgets(usrInputStr, sizeof(usrInputStr), stdin);
printf("%s\n",usrInputStr);
}else if(i == sockServer){//also need to check that this is a server
//handle new connection
addrlen = sizeof(remoteaddr);
sockClient = accept(sockServer, (struct sockaddr*)&remoteaddr, &addrlen);
if(sockClient < 0){
perror("Accept failed: ");
exit(-1);
}
FD_SET(sockClient, &master);
if (sockClient > sockServer)
{
fdmax = sockClient;
}
}
该代码不会将用户输入打印回 I/O。似乎无法理解出了什么问题。
最佳答案
三个明显的事情跳出来:
if (sockClient > sockServer)
可能应该是if (sockClient > fdmax)
。您从 stdin 读取两次,一次使用
<read
(这很好),一次使用fgets
(这很糟糕)。-
printf("%s\n",usrInputStr);
%s
格式说明符适用于 C 样式字符串,而不是任意字符数组。您没有对 rbytes 执行任何操作,那么它怎么可能知道要打印多少个字符?
关于c - C语言中从socket读取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33178505/