草庐IT

TCP-Socket

全部标签

【JavaEE】_基于TCP实现网络通信

目录1.TCP的SocketAPI1.1TCP的socketapi的两个关键类1.2面向字节流的TCP1.3UDP与TCP的区别与联系2.基于TCP实现回显服务器2.1客户端TCPEchoClient2.1.1代码2.2服务器TCPEchoServer2.2.1单线程版代码2.2.2部分代码解释2.2.3单线程版代码改进逻辑2.2.4多线程版代码2.2.5多线程版代码改进逻辑2.2.6线程池优化版代码2.3多线程版程序通信测试1.TCP的SocketAPI1.1TCP的socketapi的两个关键类1.ServerSocket,供服务器使用,使用这个类绑定服务器端口;2.Socket,既会给服

TCP 三次握手/四次挥手

TCP三次握手/四次挥手TCP基本认识什么是TCP?TCP是一种面向连接、可靠、基于字节流的协议什么是TCP连接?Socket+Seq+WindowSizeSocket:IP+PortSeq:序列号WindowSize:窗口大小如何唯一确定一个TCP连接源IP+源Port+目的IP+目的PortTCP连接数的上限?理论上限:32位IP+16位Port,即2^46实际远远达不到,取决于:最大文件描述符数量(三个等级:系统级、用户级、进程级)系统内存大小TCP与UDP区别?使用场景有什么不同?TCP有连接,UDP无连接TCP可靠,UDP不保证可靠(尽最大努力交付,可以在应用层实现可靠,如QUIC)

网络原理TCP/IP(2)

文章目录TCP协议确认应答超时重传连接管理断开连接TCP协议TCP全称为"传输控制协议(TransmissionControlProtocol").⼈如其名,要对数据的传输进⾏⼀个详细的控制;TCP协议段格式•源/目的端口号:表⽰数据是从哪个进程来,到哪个进程去;•32位序号/32位确认号:后⾯详细讲;•4位TCP报头⻓度:表⽰该TCP头部有多少个32位bit(有多少个4字节);所以TCP头部最⼤⻓度是15*4=60•6位标志位:◦URG:紧急指针是否有效◦ACK:确认号是否有效◦PSH:提⽰接收端应⽤程序⽴刻从TCP缓冲区把数据读⾛◦RST:对⽅要求重新建⽴连接;我们把携带RST标识的称为复

python socket编程7 - 使用PyQt6 开发UI界面新增实现UDP server和client单机通讯的例子

在第五篇中,简单实现了命令行下的TCP/UDPserver和client的单机通讯。在第六篇中,实现了PyQt6开发界面,TCP协议实现的单机server和client的通讯功能。这一篇,在第六篇的基础上,增加了UDPserver和client的单机通讯功能。一、界面二、对比命令行代码的封装示意1、UDPServer界面实现服务配置和数据提供2、UDPServer封装成2个部分:UDPServer和UDPServerSocketReceiveThread3、server完整代码importsocketfromPyQt6.QtCoreimportQThread,pyqtSignalclassUD

c++ - boost::asio::ip::tcp::resolver::resolve() 永远阻塞

我正在尝试创建类似于thiscode的东西在boost.asio示例中找到。套接字.h:classsome_class{private:...boost::asio::io_serviceio_service;public:some_class(){/*Thisstuffisn'tusedintheexample......butitdoesn'tchangeanything...*/io_service.run();}};套接字.cpp:usingboost::asio::ip::tcp;boolsome_class::connect(char*host,char*port){pri

socket 客户端——登录、注册

socket客户端——登录、注册新增登录、注册、上传头像接口src/api/user/index.js/***@authorWuner*@date2022/9/2714:08*@descriptionuser用户模块*/import{post}from'@/utils/http';/***登录*@paramdata*@paramdata.username=>用户名*@paramdata.password=>密码*@returns*/consturl='/socket-chat-back/user';exportconstlogin=(data)=>{returnpost(`${url}/log

c++ - 为什么调用closesock后socket accept函数不释放?

我有一个服务器应用程序打开套接字并监听连接。在应用程序中,我有一个单独的线程创建一个套接字,绑定(bind)它并调用它的监听和接受函数。当应用程序关闭时,我在创建的套接字上调用closesocket,然后等待套接字线程关闭。但是,如果线程正在等待接受函数,则线程永远不会完成。我以为调用cloasesocket后accept函数会返回。这是一个正确的想法吗?如果是这样,为什么接受函数不返回?是否有其他方法可以使accept函数返回? 最佳答案 除非select表示可以,否则不要调用accept。在那种情况下,accept永远不会阻塞。

c++ - 在创建的 QThread 中运行所需的 Qt Socket 阻塞函数。有办法过去吗?

标题很隐晦,就这样吧!我正在编写一个以非常同步的方式运行的客户端。由于协议(protocol)和服务器的设计,一切都必须按顺序发生(发送请求、等待回复、服务回复等),所以我使用阻塞套接字。这就是Qt的用武之地。在我的应用程序中,我有一个GUI线程、一个命令处理线程和一个脚本引擎线程。我在命令处理线程中创建QTcpSocket,作为我的Client类的一部分。Client类有各种方法,归结为写入套接字、读回特定数量的字节并返回结果。当我尝试从脚本引擎线程直接调用客户端方法时出现问题。Qt套接字随机超时,当使用Qt的调试版本时,我收到以下警告:QSocketNotifier:socketn

c++ - 文件 basic_socket.hpp 中的 lib boost asio 1.47.0 出错

当我尝试编译时,以下代码出现错误:voidServer::accept(void){Network::ptrconnection=Network::initialize(this->my_acceptor.get_io_service());this->my_acceptor.async_accept(connection->socket(),bind(&Server::endCmd,this,*connection,placeholders::error));}voidServer::endCmd(Networkconnection,constboost::system::error

Java网络编程之IP,端口号,通信协议(UDP,TCP)

目录1.软件架构2.网络编程三要素3.IP1.IPV42.IPV64.端口号5.协议1.UDP协议1.单播2.组播3.广播2.TCP协议1.三次握手2.四次挥手1.软件架构①C/S:客户端/服务器在用户本地需要下载安装客户端程序,在远程有一个服务器端程序。优点:画面精美,用户体验好缺点:用户需要下载更新②B/S:浏览器/服务器只需要一个浏览器,用户通过指定网址访问对应的服务器。优点:不需要开发客户端,只需要页面+服务端,用户不需要下载,打开浏览器就能使用缺点:如果应用过大,用户体验收到影响2.网络编程三要素IP,端口号,网络协议。①IP:设备在网络中的地址,是唯一的标识全称:InternetP