国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

QT下的多線程TCP客戶端和服務(wù)器

這篇具有很好參考價值的文章主要介紹了QT下的多線程TCP客戶端和服務(wù)器。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

qt下的QTcpSocket在同一個線程使用時沒有問題的,但是如果進行跨線程,很容易出現(xiàn)問題。那么有什么方法可以跨線程進行使用嗎?

答案是肯定的:使用QThread的movetothread可以完成擴線程接收。

首先是基于QTcpSocket的類 頭文件tcpsocket.h

#ifndef TCPSOCKET_H
#define TCPSOCKET_H
#include <QTcpSocket>
#include <QHostAddress>

class TcpSocket : public QTcpSocket
{
    Q_OBJECT
public:
	explicit TcpSocket( QObject *parent = NULL);
	explicit  TcpSocket(int socketdesc, QObject *parent = NULL);
    ~TcpSocket();
	bool tcpConnect(const QString ip, const int port);
signals:
	void socketSendData(const QString);
public slots:
    bool start_connt(const QString IP, const int Port);
	void WriteToData(const QByteArray basend);
	void ReadAndParseData();
    void SocketErr(QAbstractSocket::SocketError socketError);
	void slotConnect();
private:
    QString m_recvDataStr;
};

#endif // TCPSOCKET_H

然后是cpp文件tcpsocket.cpp

#include "tcpsocket.h"
#include <QDateTime>


TcpSocket::TcpSocket(QObject *parent /*= NULL*/) : QTcpSocket(parent)
{

	
}




TcpSocket::TcpSocket(int sock, QObject *parent) : QTcpSocket(parent)
{
	this->setSocketDescriptor(sock);
	connect(this, SIGNAL(readyRead()), this, SLOT(ReadAndParseData()));
	connect(this, SIGNAL(error(QAbstractSocket::SocketError)), this, SLOT(SocketErr(QAbstractSocket::SocketError)));
	connect(this, SIGNAL(connected()), this, SLOT(slotConnect()));
	connect(this, SIGNAL(disconnected()), this, SLOT(deleteLater()));

}



TcpSocket::~TcpSocket()
{


}

bool TcpSocket::tcpConnect(const QString ip, const int port)
{

	//this->abort();
	this->connectToHost(ip, port);
	bool recCon = this->waitForConnected(1000000);
	if (recCon)
	{
		connect(this, SIGNAL(readyRead()), this, SLOT(ReadAndParseData()));
		connect(this, SIGNAL(error(QAbstractSocket::SocketError)), this, SLOT(SocketErr(QAbstractSocket::SocketError)));
		//connect(this, SIGNAL(connected()), this, SLOT(slotConnect()));
		//connect(this, SIGNAL(disconnected()), this, SLOT(deleteLater()));
		//write("Connect!!");
	}
	return recCon;


}

bool TcpSocket::start_connt(const QString IP, const int Port)
{
	
	  
	    this->abort();
		this->connectToHost(IP, Port);
		this->waitForConnected();
		return true;



}
void TcpSocket::slotConnect()
{
	qDebug() << "slotConnect";

}
// 將會移進線程里面運行
void TcpSocket::ReadAndParseData()
{
	int byteLen = 0;
	QString recvStr = "";
	//wait forreadyread()
	//if (this->waitForReadyRead(0))
	{
		byteLen = this->bytesAvailable();

		if (byteLen>0)
		{

			QByteArray readNet = this->readAll();
			recvStr = QString::fromLatin1(readNet);
		}

	}

	QDateTime tim = QDateTime::currentDateTime();
	QString curtime = tim.toString("yyyy:MM:dd:hh:mm:ss:zzz");
	qDebug() << curtime << "    socket read data:" << recvStr;
	
	emit socketSendData(recvStr);
   


}

void TcpSocket::SocketErr(QAbstractSocket::SocketError socketError)
{
    TcpSocket *socket = (TcpSocket*)sender();
    qDebug()<<"sock err= "<< socketError;
}

void TcpSocket::WriteToData(const QByteArray basend)
{

	
	this->write(basend);
	
}


再次基礎(chǔ)上,創(chuàng)建tcpserver.h

#ifndef TCPSERVER_H
#define TCPSERVER_H

#include <QTcpServer>
#include <QThread>
#include <QList>
#include "tcpsocket.h"
class TcpServer : public QTcpServer
{
    Q_OBJECT
public:
    explicit  TcpServer( QObject *parent = NULL);
    ~TcpServer();
    void WriteToClient(const QByteArray  strData );
	bool openServer(const QString IpAddress, const  int PortNum);
signals:
    void dataWrite( const QByteArray );
	void serverSend(const QString); 
protected:
    void incomingConnection(qintptr socketDescriptor);
private slots:
    void disconnectSlot();
	void readDataSlot(const QString recdata);
private:
    QList<TcpSocket*> m_socketList;
};




#endif // TCPSERVER_H

和?tcpserver.cpp

#include "tcpserver.h"
#include <QDateTime>

TcpServer::TcpServer(QObject *parent) : QTcpServer(parent)
{

}

TcpServer::~TcpServer()
{
	/*   QList<TcpSocket*>::iterator it = m_socketList.begin();
	   for (; it != m_socketList.end(); )
	   {
	   TcpSocket* sock = *it;
	   it = m_socketList.erase(it);
	   sock->deleteLater();
	   sock = NULL;
	   }
	   m_socketList.clear();*/
    this->close();

}

bool TcpServer::openServer(QString IpAddress, int PortNum)
{
	bool bsucc;
	if (IpAddress.isEmpty())
	{
		bsucc = this->listen(QHostAddress::AnyIPv4, PortNum);
	}
	else
	{
	
		bsucc = this->listen(QHostAddress(IpAddress), PortNum);
	}

	return bsucc;
}

void TcpServer::incomingConnection(qintptr socketDescriptor)
{
	
    TcpSocket *socket = new TcpSocket(socketDescriptor);
    m_socketList.append(socket);
    //外部調(diào)用信號連接

	connect(socket, SIGNAL(socketSendData(const QString)), this, SLOT(readDataSlot(const QString))); // 會移進線程里


    QThread *thread = new QThread();
     connect(socket, SIGNAL(disconnected()), thread, SLOT(quit()));//線程退出
     connect(socket, SIGNAL(disconnected()), this, SLOT(disconnectSlot()));
	 connect(this, SIGNAL(dataWrite(const QByteArray)), socket, SLOT(WriteToData(const QByteArray)));

    connect(thread,SIGNAL(finished()),socket,SLOT(deleteLater()));//刪除socket

    socket->moveToThread(thread);
    thread->start();
    emit newConnection();   //文檔要求繼承本函數(shù)需要發(fā)射此信號,此處沒有與此信號連接的槽
}

void TcpServer::disconnectSlot()
{
    qDebug()<<"disconnect  ok";
}

void TcpServer::readDataSlot(const QString recvStr)
{

	QDateTime tim = QDateTime::currentDateTime();
	QString curtime = tim.toString("yyyy:MM:dd:hh:mm:ss:zzz");
	qDebug() << curtime << "    server read data:" << recvStr;
   
	serverSend(recvStr);
	  
	
}

void TcpServer::WriteToClient(const QByteArray  strData )
{
	
	emit dataWrite(strData);
	
}

在調(diào)用的時候分為客戶端和服務(wù)器兩種


	if (m_cell->m_servSel<1)						//客戶端
	{
		m_tcp = new  TcpSocket();
		bRet = m_tcp->tcpConnect(IpAddress, PortNum);
		if (bRet)
		{
			work_th = new QThread();
			// ui---線程 交互

			connect(this, SIGNAL(sig_send(const QByteArray)), m_tcp, SLOT(WriteToData(const QByteArray)));
			connect(m_tcp, SIGNAL(disconnected()), work_th, SLOT(quit()));//失去連接后線程退出
			//connect(m_tcp, SIGNAL(disconnected()), this, SLOT(disconnectSlot()));
		
			{
				connect(m_tcp, SIGNAL(socketSendData(const QString)), this, SLOT(rec_tcpClientData(const QString))); // 會移進線程里
			}
		
			connect(work_th, SIGNAL(finished()), m_tcp, SLOT(deleteLater()));//線程退出后刪除socket


		
			m_tcp->moveToThread(work_th); //會移進線程里
			work_th->start();


		}
	
	}
	else  //服務(wù)器 服務(wù)器的每一個客戶端單獨開線程,在此處不開。
	{
		m_server = new TcpServer();
		bRet = m_server->openServer(IpAddress, PortNum);
		if (bRet)
		{
			
			
			{
				connect(m_server, SIGNAL(serverSend(const QString)), this, SLOT(rec_tcpServerData(const QString)));
			}
			
		}
		
	}
	

這樣就可以完成跨線程的收發(fā)了。文章來源地址http://www.zghlxwxcb.cn/news/detail-796719.html

到了這里,關(guān)于QT下的多線程TCP客戶端和服務(wù)器的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • QT實現(xiàn)TCP通信(服務(wù)器與客戶端搭建)

    QT實現(xiàn)TCP通信(服務(wù)器與客戶端搭建)

    創(chuàng)建一個QTcpServer類對象,該類對象就是一個服務(wù)器 調(diào)用listen函數(shù)將該對象設(shè)置為被動監(jiān)聽狀態(tài),監(jiān)聽時,可以監(jiān)聽指定的ip地址,也可以監(jiān)聽所有主機地址,可以通過指定端口號,也可以讓服務(wù)器自動選擇 當(dāng)有客戶端發(fā)來連接請求時,該服務(wù)器會自動發(fā)射一個newConnection信號

    2024年02月09日
    瀏覽(27)
  • QT TCP客戶端實現(xiàn)

    QT TCP客戶端實現(xiàn)

    QTcpSocket實例首先是通過connectToHost()嘗試連接到服務(wù)器,需要指定服務(wù)器的IP地址和端口。connectToHost()是異步方式連接服務(wù)器,不會阻塞程序運行,連接后發(fā)射connected()信號。 如果需要使用阻塞方式連接服務(wù)器,則使用waitForConnected()函數(shù)阻塞程序運行,直到連接成功或失敗。

    2024年02月09日
    瀏覽(29)
  • 了解多人游戲下的客戶端與服務(wù)器體系結(jié)構(gòu)

    直連模式下,選擇一個玩家充當(dāng)服務(wù)器(房主)。如果游戲出現(xiàn)不同步,那么均按房主的世界來,玩家1可以作弊修改其游戲來影響其他玩家的世界 針對兩個玩家來說,直連連接質(zhì)量更好,延遲小 如果玩家數(shù)量很多,不同玩家間的通信則需要靠房主為中介,那通信質(zhì)量與房主

    2024年02月12日
    瀏覽(59)
  • QT-使用QTcpSocket建立TCP客戶端連接

    QT-使用QTcpSocket建立TCP客戶端連接

    使用QT的QTcpSocket建立TCP客戶端方式,十分的簡單,上手也快,代碼量不多,并且還自動支持重連接機制,也就是說如果你的服務(wù)端突然死機了,然后服務(wù)端又重啟,那么我們的客戶端這個時候是會自動去再連接的,不需要你的程序再做重連接的機制,所以我們應(yīng)用起來是十分

    2024年02月14日
    瀏覽(22)
  • TCP實現(xiàn)服務(wù)器和客戶端通信

    TCP實現(xiàn)服務(wù)器和客戶端通信

    目錄 TCP介紹 代碼實現(xiàn) server(服務(wù)器端) 代碼分析 client(客戶端) 代碼分析 結(jié)果展示 TCP (Transmission Control Protocol) 是一種面向連接的協(xié)議,用于在計算機網(wǎng)絡(luò)中傳輸數(shù)據(jù)。TCP 可以確保數(shù)據(jù)的可靠傳輸,即使在網(wǎng)絡(luò)環(huán)境不穩(wěn)定的情況下也能夠保證數(shù)據(jù)的完整性和順序。以下是

    2024年02月15日
    瀏覽(39)
  • 【Qt專欄】Qt實現(xiàn)TCP服務(wù)端和客戶端通信

    【Qt專欄】Qt實現(xiàn)TCP服務(wù)端和客戶端通信

    網(wǎng)絡(luò)通信是程序員必須會的一項生存技能,這里簡單的實現(xiàn)了服務(wù)端和客戶端通信的兩個小示例,代碼可以直接拿來用,開發(fā)環(huán)境是Qt5.9.6。 1.項目架構(gòu) 2.tcpserver.h文件 3.tcpserver.cpp文件 4.測試效果 1.項目架構(gòu) 2.tcpserver.h文件 3.tcpserver.cpp文件 4.測試效果 好了,兩個小程序?qū)懲瓴?/p>

    2024年02月12日
    瀏覽(22)
  • Qt中使用TCP服務(wù)端及客戶端

    TCP(Transmission Control Protocol)是一種可靠、高度優(yōu)化的互聯(lián)網(wǎng)通信協(xié)議,廣泛用于各類網(wǎng)絡(luò)應(yīng)用程序中。在這篇博客中,我們將介紹如何在Qt中使用TCP服務(wù)端及客戶端。 要使用Qt創(chuàng)建TCP服務(wù)器,需要完成以下步驟: 步驟1:創(chuàng)建QTcpServer對象 步驟2:監(jiān)聽連接請求 在開始監(jiān)聽之前

    2024年02月15日
    瀏覽(21)
  • 【Micropython基礎(chǔ)】TCP客戶端與服務(wù)器

    【Micropython基礎(chǔ)】TCP客戶端與服務(wù)器

    MicroPython 是 Python 的一種精簡實現(xiàn),旨在運行于微控制器和嵌入式系統(tǒng)等資源受限的環(huán)境中。它提供了一種簡單而強大的方式來編寫和運行 Python 代碼,使開發(fā)人員能夠快速地創(chuàng)建各種嵌入式應(yīng)用程序。 在嵌入式系統(tǒng)中,網(wǎng)絡(luò)通信是一個常見的需求,而 TCP(傳輸控制協(xié)議)是

    2024年04月28日
    瀏覽(30)
  • TCP客戶端及服務(wù)器端開發(fā)實踐

    TCP客戶端及服務(wù)器端開發(fā)實踐

    ① TCP客戶端應(yīng)用程序開發(fā) ② TCP服務(wù)器端應(yīng)用程序開發(fā) 客戶端程序是指運行在用戶設(shè)備上的程序,服務(wù)端程序是指運行在服務(wù)器設(shè)備上的程序,專門為客戶端提供數(shù)據(jù)服務(wù)。那如何記憶呢? 主動發(fā)起建立連接請求的是客戶端程序,等待接受連接請求的是服務(wù)端程序。 開發(fā)流

    2024年04月09日
    瀏覽(27)
  • TCP服務(wù)器監(jiān)測客戶端異常退出方法

    ????????作為服務(wù)器必須得具備監(jiān)測客戶端狀態(tài)得機制,以保證客戶端處于不同的狀態(tài),服務(wù)器進行不同得狀態(tài)處理,依次來提高實時性,可控性,并且有利于服務(wù)器得內(nèi)存管理。其中客戶端得異常處理就屬于其中得一種。 ????????客戶端得斷開情形無非就兩種情況:

    2024年02月09日
    瀏覽(33)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包