复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64#include <stdio.h> #include <signal.h> /* --->signal() */ #include <libgen.h> /* --->basename() */ #include <stdlib.h> /* --->atoi() */ #include <sys/socket.h> /* --->socket() */ #include <assert.h> /* --->assert() */ #include <netinet/in.h> /* --->struct sockaddr_in */ #include <string.h> /* --->bzero() */ #include <arpa/inet.h> /* --->inet_pton() */ #include <unistd.h> /* --->sleep() */ enum bool{ false,true }; //枚举类型bool static enum bool stop = false; /* SIGTERM信号的处理函数,触发时结束主程序中的循环*/ static void handle_term( /* int sig */ ) { stop = true; } int main(int argc, char* argv[]) { signal(SIGTERM, handle_term); if( argc <= 3) { /* basename函数可以返回路径最后一个路径分隔符之后的内容,比如basename("/usr/local/abc") 返回 abc. */ printf("usage: ./%s ip_address port_number backlogn",basename(argv[0])); return 1; } const char *ip = argv[1]; int port = atoi(argv[2]); int backlog = atoi(argv[3]); int sock = socket(PF_INET,SOCK_STREAM,0); /* socket(),PF_INET,SOCK_STREAM in <sys/socket.h> */ assert(sock >= 0); /* 构造一个IPv4的socket地址(套接字) */ struct sockaddr_in address; bzero(&address,sizeof(address)); address.sin_family = AF_INET; inet_pton(AF_INET,ip,&address.sin_addr); /* inet_pton() in <arpa/inet.h> */ address.sin_port = htons((unsigned short int)port); /* htons() in #include <netinet/in.h> */ int ret = bind(sock,(struct sockaddr *)&address,sizeof (address)); /* bind() in <sys/socket.h> */ assert(ret != -1); ret = listen(sock,backlog); assert(ret != -1); /* 循环等待连接,直到有SIGTERM信号将它中断 */ while (!stop) { sleep(1); } /* close socket */ close(sock); return 0; }
运行程序,查看结果后可得:内核中的监听队列的实际最大长度要比backlog所指定的数量要大一点。
最后
以上就是舒适爆米花最近收集整理的关于测试listen(int sockfd,int backlog)中backlog参数对listen调用的实际影响的全部内容,更多相关测试listen(int内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复