99偷拍视频精品区一区二,口述久久久久久久久久久久,国产精品夫妇激情啪发布,成人永久免费网站在线观看,国产精品高清免费在线,青青草在线观看视频观看,久久久久久国产一区,天天婷婷久久18禁,日韩动漫av在线播放直播

Qt--多線程間的互斥

一.多線程間的互斥

臨界資源--每次只允許一個線程進行訪問的資源
線程間的互斥--多個線程在同一個時刻需要訪問臨界資源
QMute類是一把線程鎖,保證線程
間的互斥--利用線程鎖能夠保證臨界資源的安全性
QMutex中的關鍵成員函數
void lock()--當鎖空閑時,獲取鎖并繼續(xù)執(zhí)行;當鎖被獲取時,阻塞并等待釋放
void unlock()--釋放鎖(同一把鎖的獲取和釋放必須在同一線程中成對出現 )
A.生產消費者問題
1.有n個生成者同時制造產品,并把產品放入倉庫中
2.有m個消費者同時需要從倉庫中取出產品
所定的規(guī)則是--當倉庫未滿,任意生產者可以存入產品,當倉庫未空,任意消費者可以取出產品
代碼示例

成都創(chuàng)新互聯公司主要從事成都網站設計、網站建設、網頁設計、企業(yè)做網站、公司建網站等業(yè)務。立足成都服務三門峽,10余年網站建設經驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:13518219792

#include <QCoreApplication>
#include <QThread>
#include <QMutex>
#include <QDebug>

static QMutex g_mutex;//線程鎖
static QString g_store;

class Producer : public QThread
{
protected:
    void run()
    {
        int count = 0;

        while(true)
        {
            g_mutex.lock();

            g_store.append(QString::number((count++) % 10));

            qDebug() << objectName() << " : " + g_store;

            g_mutex.unlock();

            msleep(1);
        }
    }
};

class Customer : public QThread
{
protected:
    void run()
    {
        while( true )
        {
            g_mutex.lock();

            if( g_store != "" )
            {
                g_store.remove(0, 1);

                qDebug() << objectName() << " : " + g_store;
            }

            g_mutex.unlock();

            msleep(1);
        }
    }
};

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    Producer p;
    Customer c;

    p.setObjectName("Producer");
    c.setObjectName("Customer");

    p.start();
    c.start();

    return a.exec();
}

運行的結果
Qt--多線程間的互斥
B.線程的死鎖概念--線程間相互等待臨界資源而造成彼此無法繼續(xù)執(zhí)行
發(fā)生死鎖的條件
1.系統(tǒng)中存在多個臨界資源且臨界資源不可搶占
2.線程需要多個臨界資源才能繼續(xù)執(zhí)行
Qt--多線程間的互斥
死鎖的避免
1.對所有的臨界資源都分配一個唯一的序號
2.對應的線程鎖也分配同樣的序號
3.系統(tǒng)中的每個線程按照嚴格遞增的次序請求資源
信號量的概念
1.信號量是特殊的線程鎖
2.信號量允許N個線程同時訪問臨界資源
3.Qt支持信號量
Qt--多線程間的互斥

#include <QtCore/QCoreApplication>
#include <QThread>
#include <QSemaphore>
#include <Qdebug>

const int SIZE = 5;
unsigned char g_buff[SIZE] = {0};
QSemaphore g_sem_free(SIZE);
QSemaphore g_sem_used(0);

class Producer : public QThread
{
protected:
    void run()
    {
        while( true )
        {
            int value = qrand() % 256;

            g_sem_free.acquire();

            for(int i=0; i<SIZE; i++)
            {
                if( !g_buff[i] )
                {
                    g_buff[i] = value;

                    qDebug() << objectName() << " generate: {" << i << ", " << value << "}";

                    break;
                }
            }

            g_sem_used.release();

            sleep(2);
        }
    }
};

class Customer : public QThread
{
protected:
    void run()
    {
        while( true )
        {
            g_sem_used.acquire();

            for(int i=0; i<SIZE; i++)
            {
                if( g_buff[i] )
                {
                    int value = g_buff[i];

                    g_buff[i] = 0;

                    qDebug() << objectName() << " consume: {" << i << ", " << value << "}";

                    break;
                }
            }

            g_sem_free.release();

            sleep(1);
        }
    }
};

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    Producer p1;
    Producer p2;
    Producer p3;

    p1.setObjectName("p1");
    p2.setObjectName("p2");
    p3.setObjectName("p3");

    Customer c1;
    Customer c2;

    c1.setObjectName("c1");
    c2.setObjectName("c2");

    p1.start();
    p2.start();
    p3.start();

    c1.start();
    c2.start();

    return a.exec();
}

運行結果圖
Qt--多線程間的互斥

二.信號與槽的連接方式

深入信號與槽的連接方式
Qt--多線程間的互斥
bool connect(const QObject sender, const char signal, const QObject receiver, const char method, Qt::ConnectionType type = Qt::AutoConnection)信號與槽的連接方式決定槽函數調用時候的相關行為
需要注意的是--每一個線程都有自己的事件隊列,線程通過事件隊列接收信號,信號在事件循環(huán)中被處理
Qt--多線程間的互斥
1.Qt::DirectConnection--立即調用--直接在發(fā)送信號的線程中調用槽函數,等價于槽函數的實時調用
Qt--多線程間的互斥
2.Qt::QueuedConnection--異步調用--信號發(fā)送至目標線程的事件隊列,由目標線程處理;當前線程繼續(xù)向下執(zhí)行
Qt--多線程間的互斥
3.Qt::BlockingQueuedConnection--同步調用--信號發(fā)送至目標線程的事件隊列,由目標線程處理;當前線程等待槽函數返回,之后繼續(xù)向下執(zhí)行
Qt--多線程間的互斥
4.Qt::AutoConnection--默認連接
Qt--多線程間的互斥
AutoConnection是connect函數第五個參數的默認值,也是工程最常用的連接方式
5.Qt::UniqueConnection--單一連接--功能與AutoConnection相同,自動確定連接類型,同一個信號與同一個槽函數只有一個連接

當前文章:Qt--多線程間的互斥
鏈接URL:http://www.yijiale78.com/article30/jjpipo.html

成都網站建設公司_創(chuàng)新互聯,為您提供手機網站建設外貿網站建設靜態(tài)網站自適應網站網站設計公司服務器托管

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都app開發(fā)公司