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

QTcpServer用函数

bool listen(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()

void	setMaxPendingConnections(int numConnections)//设置等待连接队列中连接的最大数量,默认30
void	setProxy(const QNetworkProxy & networkProxy)//为它设置代理
bool	setSocketDescriptor(qintptr socketDescriptor)//手动设置套接字描述符,取代系统自动分配
bool	listen(const QHostAddress & address = QHostAddress::Any, quint16 port = 0)//监听某端口

virtual QTcpSocket *	nextPendingConnection()//获得队列中的下一个连接
void	pauseAccepting()//停止接受新连接
void	resumeAccepting()//重启接受新连接
void	close()
bool	waitForNewConnection(int msec = 0, bool * timedOut = 0)//阻塞方式接受新连接,msec为设置超时时间,单位毫秒

QAbstractSocket::SocketError	serverError() const
QString		errorString() const//产生错误的字符串
int		maxPendingConnections() const
QNetworkProxy	proxy() const
qintptr	socketDescriptor() const
QHostAddress	serverAddress() const
quint16		serverPort() const
bool		isListening() const
virtual bool	hasPendingConnections() const

Signals
void acceptError(QAbstractSocket::SocketError socketError)
void newConnection()
Protected Functions
void addPendingConnection(QTcpSocket * socket)
virtual void incomingConnection(qintptr socketDescriptor)


你可能感兴趣的:(Qt模块化笔记之network)