c udp服务器端一对多持续接收消息,C - 使用select在多个端口上侦听的简单ipv6 udp服务器。从一个端口接收消息,而不是另一个...

#include

#include

#include

#include

#include

int max(int socket_handle[]);

int main(void)

{

int max_clients_allowed = 2;

int socket_handle[max_clients_allowed];

int client_handle[max_clients_allowed];

struct sockaddr_in6 server_address[max_clients_allowed];

struct sockaddr_in6 client_address[max_clients_allowed];

char buffer[1000];

socklen_t client_length;

fd_set read_handles;

struct timeval timeout_interval;

int bytes_received;

int port_number = 9000;

int retval;

int i;

printf("Hello, human.\n");

for (i = 0; i < max_clients_allowed; i++)

{

printf("Creating socket%d on port: %d\n", i, port_number + i);

socket_handle[i] = socket(PF_INET6,SOCK_DGRAM,0);

memset(&server_address[i], 0, sizeof(server_address[i]));

server_address[i].sin6_family = AF_INET6;

server_address[i].sin6_addr=in6addr_any;

server_address[i].sin6_port=htons(port_number + i);

if(bind(socket_handle[i], (struct sockaddr *)&server_address[i], sizeof(server_address[i])) < 0)

{

perror("Unable to bind.");

return -1;

}

else

{

printf("Bind %d successful.\n", i);

}

}

while (1) {

FD_ZERO(&read_handles);

FD_SET(socket_handle[0], &read_handles);

FD_SET(socket_handle[1], &read_handles);

timeout_interval.tv_sec = 2;

timeout_interval.tv_usec = 500000;

retval = select(max(socket_handle) + 1, &read_handles, NULL, NULL, &timeout_interval);

if (retval == -1)

{

printf("Select error\n");

//error

}

else if ((retval = 0))

{

printf("timeout\n");

}

else

{

//good

client_length = sizeof(struct sockaddr*);

for (i = 0; i < max_clients_allowed; i++)

{

if (FD_ISSET(socket_handle[i], &read_handles))

{

if((bytes_received = recvfrom(socket_handle[i],buffer,sizeof(buffer),0,(struct sockaddr *)&client_address[i], (socklen_t*)&client_length)) < 0)

{

perror("Error in recvfrom.");

break;

}

printf("\nData received:");

printf("\n--------------\n");

printf("%s", buffer);

}

}

}

}

}

int max(int socket_handle[])

{

if (socket_handle[0] > socket_handle[1])

{

return socket_handle[0];

}

return socket_handle[1];

}

该代码应该绑定到端口9000和9001.它们使用select来查看哪些套接字有传入数据,然后打印该消息。

我假设它与我的recvfrom函数有关。我试过用参数玩弄没有用处。

另一个问题可能是当我设置套接字时,我正在使用sin6.addr = in6addr_any。我很确定PF_INET6和AF_INET6是正确的,但这也可能是一个问题。我一直在玩这个,但是我找不到这个bug。如果有人能指出我的错误,我会很感激,所以我可以修复它。我知道我正在完成这项工作。

这是一个家庭作业的问题,老师给我们的测试程序和它的作用仅仅是在端口发送一个消息9000

2013-03-07

Cool Joe

+0

请在这里展示你的代码 - pastebin.com超载,不会让我看看。 –

2013-03-07 00:35:21

+1

Pastebin现在正在关闭。请删除您的代码,以证明您的问题,然后编辑您的问题以显示实际代码。 –

2013-03-07 00:35:28

+0

@Barmer代码复制/粘贴在这里 –

2013-03-07 00:44:41

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值