热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Socket套接字编程(TCP基本编程)

Socket函数#include#includeintsocket(intdomain,inttype,intprotoco

Socket函数

#include
#include
int socket(int domain, int type, int protocol);

创建一个套接字用于通信。

domain :指定通信协议族(protocolfamily)


type:指定socket类型,流式套接字SOCK_STREAM,数据报套接字SOCK_DGRAM,原始套接字SOCK_RAW


protocol :协议类型



TCP客户端/服务器流程图



bind函数

#include
#include
int bind(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

用于绑定一个本地地址到套接字。

参数说明(后面函数参数同此)

sockfd:socket函数返回的套接字

addr:要绑定的地址,并将其转化为通用地址结构


addrlen:地址长度

listen函数

#include
#include
int listen(int sockfd, int backlog);

listen函数应该在调用socket和bind函数之后,调用函数accept之前调用。

对于给定的监听套接字,内核要维护两个队列:

1、未完成链接队列:已由客户端发出并到达服务器,服务器正在等待完成相应的TCP三路握手过程,套接字处于SYN_RCVD状态

2、已完成链接队列:每个已完成TCP三路握手过程的客户端,套接字处于ESTABLISHED状态。

三路握手过程如图



accept函数

#include
#include
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);

从已完成连接队列返回第一个连接,产生一个socket套接字用于与客户端进行通信,如果已完成连接队列为空,则阻塞。


connect函数

#include
#include
int connect(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

建立一个连接至addr所指定(客户端)的套接字。


代码实例

服务器端代码

#include
#include
#include
#include
#include
#include
#include
#include
int main(int argc,char * argv[])
{int listenfd,connfd;char sendbuf[100]= {"got your msg"},revbuf[100]= {};struct sockaddr_in ser,clt;socklen_t len=sizeof(clt);listenfd=socket(AF_INET,SOCK_STREAM,0);ser.sin_family = AF_INET;ser.sin_port = htons(8001);ser.sin_addr.s_addr = inet_addr("127.0.0.1");if(bind(listenfd,(struct sockaddr*)&ser,sizeof(ser))<0){printf("bind failed!\n");exit(0);}if(listen(listenfd,SOMAXCONN)<0){printf("listen failed!\n");exit(0);}cOnnfd=accept(listenfd,(struct sockaddr*)&clt,(socklen_t *)&len);if(cOnnfd==-1){printf("connect failed!\n");exit(0);}for(;;){int ret=read(connfd,revbuf,sizeof(revbuf));if(ret<0){printf("read failed!\n");exit(0);}else if(ret==0){printf("client closed\n");exit(0);}printf("server revmsg:%s\n",revbuf);write(connfd,sendbuf,sizeof(sendbuf));memset(revbuf,0,sizeof(revbuf));}close(listenfd);close(connfd);return 0;
}

客户端代码

#include
#include
#include
#include
#include
#include
#include
#include
int main(int argc,char *argv[])
{struct sockaddr_in user;int sockfd;char sendbuf[100],revbuf[100];sockfd=socket(AF_INET,SOCK_STREAM,0);if(sockfd==-1){printf("socket failed!\n");exit(0);}user.sin_family = AF_INET;user.sin_port = htons(8001);user.sin_addr.s_addr = inet_addr("127.0.0.1");if ( connect(sockfd, (struct sockaddr*) (&user), sizeof(user)) <0){perror("connect failed!\n");exit(0);}while(~scanf("%s",sendbuf)){write(sockfd,sendbuf,sizeof(sendbuf));read(sockfd,revbuf,sizeof(revbuf));printf("client revmsg:%s\n",revbuf);memset(sendbuf,0,sizeof(sendbuf));memset(sendbuf,0,sizeof(revbuf));}close(sockfd);return 0;
}



客户端中断关闭





推荐阅读
  • 本文深入探讨了UNIX/Linux系统中的进程间通信(IPC)机制,包括消息传递、同步和共享内存等。详细介绍了管道(Pipe)、有名管道(FIFO)、Posix和System V消息队列、互斥锁与条件变量、读写锁、信号量以及共享内存的使用方法和应用场景。 ... [详细]
  • HDU 2871 内存管理问题(线段树优化)
    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2871。本题涉及内存管理操作,包括重置、申请、释放和查询内存块。通过使用线段树进行高效管理和维护。 ... [详细]
  • 本文详细解析了2019年西安邀请赛中的一道树形动态规划题目——J题《And And And》。题目要求计算树中所有子路径异或值为0的集合数量,通过深入分析和算法优化,提供了高效的解决方案。 ... [详细]
  • 本文介绍了一个经典的算法问题——活动选择问题,来源于牛客网的比赛题目。该问题要求从一系列活动集合中选出最多数量的相容活动,确保这些活动的时间段不重叠。 ... [详细]
  • 本文深入探讨了 Delphi 中类对象成员的核心概念,包括 System 单元的基础知识、TObject 类的定义及其方法、TClass 的作用以及对象的消息处理机制。文章不仅解释了这些概念的基本原理,还提供了丰富的补充和专业解答,帮助读者全面理解 Delphi 的面向对象编程。 ... [详细]
  • 烤鸭|本文_Spring之Bean的生命周期详解
    烤鸭|本文_Spring之Bean的生命周期详解 ... [详细]
  • 掌握Mosek矩阵运算,轻松应对优化挑战
    本篇文章继续深入探讨Mosek学习笔记系列,特别是矩阵运算部分,这对于优化问题的解决至关重要。通过本文,您将了解到如何高效地使用Mosek进行矩阵初始化、线性代数运算及约束域的设定。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文详细介绍了如何解压并安装MySQL集群压缩包,创建用户和组,初始化数据库,配置环境变量,并启动相关服务。此外,还提供了详细的命令行操作步骤和常见问题的解决方案。 ... [详细]
  • 圆形进度指示器忽略宽度/高度属性并且不缩放 ... [详细]
  • KMP算法是处理字符串匹配的一种高效算法它首先用O(m)的时间对模板进行预处理,然后用O(n)的时间完成匹配。从渐进的意义上说,这样时间复 ... [详细]
  • springMVC JRS303验证 ... [详细]
  • 本题探讨如何在两个长度为 n 的整数序列中,找到它们的最长公共子序列(LCS)。题目保证第一个序列中的元素各不相同。我们将深入分析并提供一种高效的求解方法。 ... [详细]
  • KMP算法是一种高效的字符串模式匹配算法,能够在不进行回溯的情况下完成匹配,其时间复杂度为O(m+n),其中m和n分别为文本串和模式串的长度。本文将详细介绍KMP算法的工作原理,并提供C语言实现。 ... [详细]
  • 通过分析和解决找零钱问题,深入理解贪心算法的应用。本文提供详细的C语言代码实现及解析。 ... [详细]
author-avatar
克乄浪木守
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有