Qt模块化笔记之network——TcpServer与监听说明

来源:互联网 发布:网络渗透软件 编辑:程序博客网 时间:2024/05/01 13:28

QTcpServer用函数boollisten(const QHostAddress & address = QHostAddress::Any, quint16 port = 0)监听某个端口,如果有新连接进来就发出newConnection()信号,连接过程中出错的话就发出acceptError(QAbstractSocket::SocketError socketError)信号。

在接受连接的过程中,应当是有一个队列,等待的连接都将放入连接队列中,名词PendingConnections中的Pending意为即将发生的,在等待中的。

当队列中有等待的连接时,可用函数virtual QTcpSocket *nextPendingConnection()获得这个连接,并为这个连接分配一部"电话"(即函数返回的QTcpSocket),通信就建立了。然后可通过这个返回的QTcpSocket与客户端通信。值得注意的是,这个返回的socket不可用于另一个线程。

这是一种方式,另一种方式可继承这个类,重写它的Protected Function:

virtual void incomingConnection(qintptr socketDescriptor)

这个函数在有连接时自动执行。

socketDescriptor为套接字描述符,通俗理解为,系统为这个连接进来的套接字自动分配了个ID,用于区分不同套接字,是个整数值。将这个ID传给套接字就行了。网上说它和文件的句柄类似。

————————————————————————————————————————————————————————————
下面看下这个QTcpServer
公有函数:
QTcpServer(QObject * parent = 0)virtual~QTcpServer()voidsetMaxPendingConnections(int numConnections)//设置等待连接队列中连接的最大数量,默认30voidsetProxy(const QNetworkProxy & networkProxy)//为它设置代理boolsetSocketDescriptor(qintptr socketDescriptor)//手动设置套接字描述符,取代系统自动分配boollisten(const QHostAddress & address = QHostAddress::Any, quint16 port = 0)//监听某端口virtual QTcpSocket *nextPendingConnection()//获得队列中的下一个连接voidpauseAccepting()//停止接受新连接voidresumeAccepting()//重启接受新连接voidclose()boolwaitForNewConnection(int msec = 0, bool * timedOut = 0)//阻塞方式接受新连接,msec为设置超时时间,单位毫秒QAbstractSocket::SocketErrorserverError() constQStringerrorString() const//产生错误的字符串intmaxPendingConnections() constQNetworkProxyproxy() constqintptrsocketDescriptor() constQHostAddressserverAddress() constquint16serverPort() constboolisListening() constvirtual boolhasPendingConnections() const

Signals
voidacceptError(QAbstractSocket::SocketError socketError)voidnewConnection()Protected Functions
voidaddPendingConnection(QTcpSocket * socket)virtual voidincomingConnection(qintptr socketDescriptor)


0 0
原创粉丝点击