欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在C++?Qt中實現(xiàn)異步散列器的代碼示例

 更新時間:2024年09月11日 08:29:12   作者:夢起丶  
在很多工作中,我們需要計算數(shù)據(jù)或者文件的散列值,例如登錄或下載文件,而在?Qt?中,負責這項工作的類為?QCryptographicHash,本文給大家介紹了在C++?Qt中實現(xiàn)異步散列器的代碼示例,需要的朋友可以參考下

【寫在前面】

在很多工作中,我們需要計算數(shù)據(jù)或者文件的散列值,例如登錄或下載文件。

而在 Qt 中,負責這項工作的類為 QCryptographicHash。

關(guān)于 QCryptographicHash

QCryptographicHash 是 Qt 框架中提供的一個用于生成加密散列(哈希值)的類。該類可以將任意長度的輸入(二進制或文本數(shù)據(jù))轉(zhuǎn)換成固定長度的輸出(哈希值),這一過程是不可逆的。QCryptographicHash 支持多種哈希算法,包括 MD4、MD5、SHA-1、SHA-224、SHA-256、SHA-384 和 SHA-512 等,這些算法在數(shù)據(jù)完整性校驗、密碼存儲、數(shù)字簽名等應用場景中非常有用。

主要特點:

支持多種哈希算法:QCryptographicHash 提供了多種哈希算法的支持,允許開發(fā)者根據(jù)具體需求選擇合適的算法。

簡單易用的接口:QCryptographicHash 提供了簡單易用的接口來計算哈希值。開發(fā)者可以通過調(diào)用 QCryptographicHash::hash() 靜態(tài)方法或創(chuàng)建 QCryptographicHash 對象并使用 addData() 和 result() 方法來計算哈希值。

逐塊計算:`QCryptographicHash 還可以逐塊地計算哈希值,這對于處理大文件或流式數(shù)據(jù)非常有用。

可重復使用:QCryptographicHash 對象可以多次使用。當計算完一個哈希值后,可以通過調(diào)用 reset() 方法重置對象,然后繼續(xù)計算新的哈希值。

然鵝, 雖然 QCryptographicHash 很優(yōu)秀,但它最大的問題在于其散列值的計算是同步的( 即阻塞 ),對小數(shù)據(jù)來說并沒什么影響,但對大數(shù)據(jù)來說則意味明顯卡頓。

因此,我將 QCryptographicHash 進行簡單封裝,擴展了實用性的同時并將計算改為異步,還增加了進度通知和結(jié)束通知。

【正文開始】

先來看看 AsyncHasher 的使用效果圖:

AsyncHasher 的使用方法非常簡單:

  • 包含頭文件:在使用 AsyncHasher 之前,需要包含相應的頭文件 #include "asynchasher.h"。

  • 通過 setSource / setSourceText / setSourceData/ setSourceObject 設置源目標。

  • 通過 void hashProgress(qint64 processed, qint64 total) 來獲取進度,void finished() 通知計算結(jié)束。

  • 通過 QString hashValue() const 獲取最終結(jié)果。

例如 C++ 使用:

    AsyncHasher *hasher = new AsyncHasher;
    hasher->setSourceText("Test Text");
    QObject::connect(hasher, &AsyncHasher::finished, [hasher]{
        qDebug() << hasher->hashValue();
    });

并且我還做了 Qml 適配,使用方法:

    AsyncHasher {
        id: textHasher
        algorithm: AsyncHasher.Md5
        onStarted: {
            startTime = Date.now();
        }
        onFinished: {
            totalTime = Date.now() - startTime;
            console.log("HashValue:", hashValue, "time:", totalTime);
        }
        property real startTime: 0
        property real totalTime: 0
    }

完整頭文件如下:

#ifndef ASYNCHASHER_H
#define ASYNCHASHER_H

#include <QCryptographicHash>
#include <QFuture>
#include <QObject>
#include <QUrl>

QT_FORWARD_DECLARE_CLASS(QNetworkAccessManager);

QT_FORWARD_DECLARE_CLASS(AsyncHasherPrivate);

class AsyncHasher : public QObject
{
    Q_OBJECT

    Q_PROPERTY(QCryptographicHash::Algorithm algorithm READ algorithm WRITE setAlgorithm NOTIFY algorithmChanged)
    Q_PROPERTY(bool asynchronous READ asynchronous WRITE setAsynchronous NOTIFY asynchronousChanged)
    Q_PROPERTY(QString hashValue READ hashValue NOTIFY hashValueChanged)
    Q_PROPERTY(int hashLength READ hashLength NOTIFY hashLengthChanged)
    Q_PROPERTY(QUrl source READ source WRITE setSource NOTIFY sourceChanged)
    Q_PROPERTY(QString sourceText READ sourceText WRITE setSourceText NOTIFY sourceTextChanged)
    Q_PROPERTY(QByteArray sourceData READ sourceData WRITE setSourceData NOTIFY sourceDataChanged)
    Q_PROPERTY(QObject* sourceObject READ sourceObject WRITE setSourceObject NOTIFY sourceObjectChanged)

public:
    Q_ENUMS(QCryptographicHash::Algorithm);

    explicit AsyncHasher(QObject *parent = nullptr);
    ~AsyncHasher();

    QNetworkAccessManager *networkManager() const;

    QCryptographicHash::Algorithm algorithm();
    void setAlgorithm(QCryptographicHash::Algorithm algorithm);

    bool asynchronous() const;
    void setAsynchronous(bool async);

    QString hashValue() const;

    int hashLength() const;

    QUrl source() const;
    void setSource(const QUrl &source);

    QString sourceText() const;
    void setSourceText(const QString &sourceText);

    QByteArray sourceData() const;
    void setSourceData(const QByteArray &sourceData);

    QObject *sourceObject() const;
    void setSourceObject(QObject *sourceObject);

    bool operator==(const AsyncHasher &hasher);
    bool operator!=(const AsyncHasher &hasher);

    QFuture<QByteArray> static hash(const QByteArray &data, QCryptographicHash::Algorithm algorithm);

signals:
    void algorithmChanged();
    void asynchronousChanged();
    void hashValueChanged();
    void hashLengthChanged();
    void sourceChanged();
    void sourceTextChanged();
    void sourceDataChanged();
    void sourceObjectChanged();
    void hashProgress(qint64 processed, qint64 total);
    void started();
    void finished();

private slots:
    void setHashValue(const QString &value);

private:
    Q_DECLARE_PRIVATE(AsyncHasher);
    QScopedPointer<AsyncHasherPrivate> d_ptr;
};

#endif // ASYNCHASHER_H

【結(jié)語】

以上就是在C++ Qt中實現(xiàn)異步散列器的代碼示例的詳細內(nèi)容,更多關(guān)于C++ Qt異步散列器的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 人臉檢測中AdaBoost算法詳解

    人臉檢測中AdaBoost算法詳解

    這篇文章主要為大家詳細介紹了人臉檢測中AdaBoost算法的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++實現(xiàn)學生管理系統(tǒng)

    C++實現(xiàn)學生管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)學生管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C++深度探索虛函數(shù)覆蓋示例

    C++深度探索虛函數(shù)覆蓋示例

    虛函數(shù)主要通過V-Table虛函數(shù)表來實現(xiàn),該表主要包含一個類的虛函數(shù)的地址表,可解決繼承、覆蓋的問題,下面這篇文章主要給大家介紹了如何通過一篇文章帶你掌握C++虛函數(shù)的來龍去脈,需要的朋友可以參考下
    2022-12-12
  • PyQt5利用Qt Designer實現(xiàn)簡單界面交互

    PyQt5利用Qt Designer實現(xiàn)簡單界面交互

    本文主要介紹了PyQt5利用Qt Designer實現(xiàn)簡單界面交互,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2025-03-03
  • HDOJ 1443 約瑟夫環(huán)的最新應用分析詳解

    HDOJ 1443 約瑟夫環(huán)的最新應用分析詳解

    本篇文章是對HDOJ 1443 約瑟夫環(huán)的最新應用進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++回溯算法深度優(yōu)先搜索舉例分析

    C++回溯算法深度優(yōu)先搜索舉例分析

    回溯在迷宮搜索中使用很常見,就是這條路走不通,然后返回前一個路口,繼續(xù)下一條路?;厮菟惴ㄕf白了就是窮舉法,下面讓我們一起來看看回溯算法深度優(yōu)先搜索吧
    2022-03-03
  • C++實現(xiàn)控制臺隨機迷宮的示例代碼

    C++實現(xiàn)控制臺隨機迷宮的示例代碼

    本文主要介紹了C++實現(xiàn)控制臺隨機迷宮的示例代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • C++迭代器iterator詳解

    C++迭代器iterator詳解

    這篇文章主要為大家詳細介紹了C++迭代器模式Iterator,具有一定的參考價值,感興趣的小伙伴們可以參考一下希望能給你帶來幫助
    2021-08-08
  • vs2022?qt環(huán)境搭建調(diào)試的方法步驟

    vs2022?qt環(huán)境搭建調(diào)試的方法步驟

    最近net6和vs2022發(fā)布,本文就詳細的介紹一下vs2022?qt環(huán)境搭建調(diào)試的方法步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • DSP中浮點轉(zhuǎn)定點運算--定點數(shù)的加減乘除運算

    DSP中浮點轉(zhuǎn)定點運算--定點數(shù)的加減乘除運算

    本文主要介紹DSP中定點數(shù)的加減乘除運算,很值得學習一下,需要的朋友可以參考一下。
    2016-06-06

最新評論