当前位置: 首页 > news >正文

QT 笔记

  •  HTTPS SSL配置
    • 下载
    • 配置
  • 子父对象
QTimer *timer = new QTimer;         // QTimer inherits QObject
timer->inherits("QTimer");          // returns true
timer->inherits("QObject");         // returns true
timer->inherits("QAbstractButton"); // returns false
  • 文件权限
extern Q_CORE_EXPORT int qt_ntfs_permission_lookup;
qt_ntfs_permission_lookup++; // turn checking on
qt_ntfs_permission_lookup--; // turn it off againQFile::Permissions pers;    QFile file("D:/DOWN/f.txt");  file.open(QFile::ReadOnly);    pers =file.permissions();    qDebug() <<pers;  file.setPermissions(QFile::ReadOwner);    qDebug() <<file.permissions();    file.setPermissions(pers);
  • QMediaPlayer本地解码器

WIN上下载k-lite或者LAV Filters安装即可。

  • GC
// 创建实例 
QObjectCleanupHandler *cleaner = new QObjectCleanupHandler; 
// 创建窗口 
QPushButton *w = new QPushButton("Remove Me"); 
w->show(); 
// 注册第一个按钮 
cleaner->add(w); 
// 如果第一个按钮点击之后,删除自身 
connect(w, SIGNAL(clicked()), w, SLOT(deleteLater())); 
// 创建第二个按钮,注意,这个按钮没有任何动作 
w = new QPushButton("Nothing"); 
cleaner->add(w); 
w->show(); 
// 创建第三个按钮,删除所有 
w = new QPushButton("Remove All"); 
cleaner->add(w); 
connect(w, SIGNAL(clicked()), cleaner, SLOT(deleteLater())); 
w->show(); 
  • 弱指针
// QPointer 表现类似普通指针 
QDate *mydate = new QDate(QDate::currentDate()); 
QPointer mypointer = mydata; 
mydate->year();    // -> 2005 
mypointer->year(); // -> 2005 // 当对象 delete 之后,QPointer 会有不同的表现 
delete mydate; if(mydate == NULL) printf("clean pointer"); 
else printf("dangling pointer"); 
// 输出 dangling pointer if(mypointer.isNull()) printf("clean pointer"); 
else printf("dangling pointer"); 
// 输出 clean pointer 
  • 内置图标
QStyle::SP_TitleBarMenuButton
  • pro文件解析

宏定义

  • QScroller
ui->listWidget->setHorizontalScrollMode(QListWidget::ScrollPerPixel);
QScroller::grabGesture(ui->listWidget,QScroller::LeftMouseButtonGesture);
  • 代码重构

  • QtCreator软件的配置文件

C:\Users\Administrator\AppData\Roaming\QtProject

  • QtCreator UI

  • 守护进程

/*为了使得兼容任意程序,特意提炼出来共性,增加了多种设置。可设置检测的程序名称。可设置udp通信端口。可设置超时次数。自动记录已重启次数。自动记录最后一次重启时间。是否需要重新刷新桌面。可重置当前重启次数和最后重启时间。自动隐藏的托盘运行或者后台运行。提供界面设置程序名称已经开启和暂停服务。*/1#pragma execution_character_set("utf-8")
2#include "frmmain.h"
3#include "ui_frmmain.h"
4#include "qtimer.h"
5#include "qudpsocket.h"
6#include "qsharedmemory.h"
7#include "qprocess.h"
8#include "qdatetime.h"
9#include "qapplication.h"
10#include "qdesktopservices.h"
11#include "qmessagebox.h"
12#if (QT_VERSION > QT_VERSION_CHECK(5,0,0))
13#include "qstandardpaths.h"
14#endif
15
16#include "app.h"
17
18frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
19{
20    ui->setupUi(this);
21    this->initForm();
22}
23
24frmMain::~frmMain()
25{
26    delete ui;
27}
28
29void frmMain::changeEvent(QEvent *event)
30{
31    //隐藏当前界面,最小化到托盘
32    if(event->type() == QEvent::WindowStateChange) {
33        if(windowState() & Qt::WindowMinimized) {
34            hide();
35        }
36    }
37
38    QWidget::changeEvent(event);
39}
40
41void frmMain::initForm()
42{
43    count = 0;
44    ok = false;
45
46    //每秒钟定时询问心跳
47    timerHeart = new QTimer(this);
48    timerHeart->setInterval(2000);
49    connect(timerHeart, SIGNAL(timeout()), this, SLOT(sendHearData()));
50
51    //从6050端口开始,如果绑定失败则将端口加1,直到绑定成功
52    udp = new QUdpSocket(this);
53    int port = 6050;
54    while(!udp->bind(port)) {
55        port++;
56    }
57
58    connect(udp, SIGNAL(readyRead()), this, SLOT(readData()));
59
60    if (App::TargetAppName.isEmpty()) {
61        ui->btnStart->setText("启动");
62        ui->btnStart->setEnabled(false);
63        timerHeart->stop();
64    } else {
65        ui->btnStart->setText("暂停");
66        ui->btnStart->setEnabled(true);
67        timerHeart->start();
68    }
69
70    ui->txtAppName->setText(App::TargetAppName);
71    ui->txtAppName->setFocus();
72}
73
74void frmMain::sendHearData()
75{
76    udp->writeDatagram("hello", QHostAddress::LocalHost, App::TargetAppPort);
77
78    //判断当前是否没有回复
79    if (!ok) {
80        count++;
81    } else {
82        count = 0;
83        ok = false;
84    }
85
86    //如果超过规定次数没有收到心跳回复,则超时重启
87    if (count >= App::TimeoutCount) {
88        timerHeart->stop();
89
90        QSharedMemory mem(App::TargetAppName);
91        if (!mem.create(1)) {
92            killApp();
93        }
94
95        QTimer::singleShot(1000 , this, SLOT(killOther()));
96        QTimer::singleShot(3000 , this, SLOT(startApp()));
97        QTimer::singleShot(4000 , this, SLOT(startExplorer()));
98    }
99}
100
101void frmMain::killApp()
102{
103    QProcess *p = new QProcess;
104    p->start(QString("taskkill /im %1.exe /f").arg(App::TargetAppName));
105}
106
107void frmMain::killOther()
108{
109    QProcess *p = new QProcess;
110    p->start(QString("taskkill /im %1.exe /f").arg("WerFault"));
111
112    //重建缓存,彻底清除托盘图标
113    if (App::ReStartExplorer) {
114        QProcess *p1 = new QProcess;
115        p1->start("taskkill /f /im explorer.exe");
116    }
117}
118
119void frmMain::startApp()
120{
121    if (ui->btnStart->text() == "开始" || ui->btnStart->text() == "启动") {
122        count = 0;
123        return;
124    }
125
126    QProcess *p = new QProcess;
127    p->start(QString(""%1/%2.exe"").arg(qApp->applicationDirPath()).arg(App::TargetAppName));
128
129    count = 0;
130    ok = true;
131    timerHeart->start();
132
133    App::ReStartCount++;
134    App::ReStartLastTime = QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss");
135    App::writeConfig();
136
137    ui->labCount->setText(QString("已重启 %1 次").arg(App::ReStartCount));
138    ui->labInfo->setText(QString("最后一次重启在 %1").arg(App::ReStartLastTime));
139}
140
141void frmMain::startExplorer()
142{
143    //取得操作系统目录路径,指定操作系统目录下的explorer程序,采用绝对路径,否则在64位操作系统下无效
144#if (QT_VERSION > QT_VERSION_CHECK(5,0,0))
145    QString str = QStandardPaths::writableLocation(QStandardPaths::ApplicationsLocation);
146#else
147    QString str = QDesktopServices::storageLocation(QDesktopServices::ApplicationsLocation);
148#endif
149
150    if (App::ReStartExplorer) {
151        str = QString("%1\\Windows\\explorer.exe").arg(str.mid(0, 2));
152        QProcess *p = new QProcess(this);
153        p->start(str);
154    }
155}
156
157void frmMain::readData()
158{
159    QByteArray tempData;
160    do {
161        tempData.resize(udp->pendingDatagramSize());
162        udp->readDatagram(tempData.data(), tempData.size());
163        QString data = QLatin1String(tempData);
164        if (data.right(2) == "OK") {
165            count = 0;
166            ok = true;
167        }
168    } while (udp->hasPendingDatagrams());
169}
170
171void frmMain::on_btnOk_clicked()
172{
173    App::TargetAppName = ui->txtAppName->text();
174    if (App::TargetAppName == "") {
175        QMessageBox::critical(this, "提示", "应用程序名称不能为空!");
176        ui->txtAppName->setFocus();
177        return;
178    }
179
180    App::writeConfig();
181    ui->btnStart->setEnabled(true);
182}
183
184void frmMain::on_btnStart_clicked()
185{
186    count = 0;
187    if (ui->btnStart->text() == "暂停") {
188        timerHeart->stop();
189        ui->btnStart->setText("开始");
190    } else {
191        timerHeart->start();
192        ui->btnStart->setText("暂停");
193    }
194}
195
196void frmMain::on_btnReset_clicked()
197{
198    App::ReStartCount = 0;
199    App::ReStartLastTime = "2019-01-01 12:00:00";
200    App::writeConfig();
201
202    ui->txtAppName->setText(App::TargetAppName);
203    ui->labCount->setText(QString("已重启 %1 次").arg(App::ReStartCount));
204    ui->labInfo->setText(QString("最后一次重启在 %1").arg(App::ReStartLastTime));
205    QMessageBox::information(this, "提示", "重置配置文件成功!");
206}
主程序使用核心代码:
1#include "applive.h"
2#include "qmutex.h"
3#include "qudpsocket.h"
4#include "qstringlist.h"
5#include "qapplication.h"
6#include "qdatetime.h"
7#include "qdebug.h"
8
9#define TIMEMS qPrintable(QTime::currentTime().toString("HH:mm:ss zzz"))
10
11QScopedPointer<AppLive> AppLive::self;
12AppLive *AppLive::Instance()
13{
14    if (self.isNull()) {
15        QMutex mutex;
16        QMutexLocker locker(&mutex);
17        if (self.isNull()) {
18            self.reset(new AppLive);
19        }
20    }
21
22    return self.data();
23}
24
25AppLive::AppLive(QObject *parent) : QObject(parent)
26{
27    udpServer  = new QUdpSocket(this);
28
29    QString name = qApp->applicationFilePath();
30    QStringList list = name.split("/");
31    appName = list.at(list.count() - 1).split(".").at(0);
32}
33
34void AppLive::readData()
35{
36    QByteArray tempData;
37
38    do {
39        tempData.resize(udpServer->pendingDatagramSize());
40        QHostAddress sender;
41        quint16 senderPort;
42        udpServer->readDatagram(tempData.data(), tempData.size(), &sender, &senderPort);
43        QString data = QLatin1String(tempData);
44
45        if (data == "hello") {
46            udpServer->writeDatagram(QString("%1OK").arg(appName).toLatin1(), sender, senderPort);
47        }
48    } while (udpServer->hasPendingDatagrams());
49}
50
51bool AppLive::start(int port)
52{
53    bool ok = udpServer->bind(port);
54    if (ok) {
55        connect(udpServer, SIGNAL(readyRead()), this, SLOT(readData()));
56        qDebug() << TIMEMS << "Start AppLive Ok";
57    }
58
59    return ok;
60}
61
62void AppLive::stop()
63{
64    udpServer->abort();
65    disconnect(udpServer, SIGNAL(readyRead()), this, SLOT(readData()));
66}
  • Qt密钥生成器

在很多商业软件中,需要提供一些可以试运行的版本,这样就需要配套密钥机制来控制,纵观大部分的试用版软件,基本上采用以下几种机制来控制。远程联网激活,每次启动都联网查看使用时间等,这种方法最完美,缺点是没法联网的设备就歇菜了。通过获取本地的硬盘+CPU等硬件的编号,做一个运算,生成一个激活码,超过半数的软件会采用此方法,缺点是不能自由控制软件的其他参数,比如软件中添加的设备数量的控制。设定一个运行到期时间+数量限制+已运行时间的密钥文件,发给用户配套软件使用,缺点是如果仅仅设置的是运行到期时间,用户可以更改电脑时间来获取更长的使用时间,在电脑不联网的情况下。本demo采用抛砖引玉的形式,用第三种方法来实现,密钥文件采用最简单的异或加密,可以自行改成其他加密方法。
核心代码:
1#include "frmmain.h"
2#include "ui_frmmain.h"
3#include "qmessagebox.h"
4#include "qfile.h"
5
6frmMain::frmMain(QWidget *parent) : QWidget(parent), ui(new Ui::frmMain)
7{
8    ui->setupUi(this);
9    this->initForm();
10}
11
12frmMain::~frmMain()
13{
14    delete ui;
15}
16
17void frmMain::initForm()
18{
19    QStringList min;
20    min << "1" << "5" << "10" << "20" << "30";
21    for (int i = 1; i <= 24; i++) {
22        min << QString::number(i * 60);
23    }
24
25    ui->cboxMin->addItems(min);
26    ui->cboxMin->setCurrentIndex(1);
27    ui->dateEdit->setDate(QDate::currentDate());
28
29    for (int i = 5; i <= 150; i = i + 5) {
30        ui->cboxCount->addItem(QString("%1").arg(i));
31    }
32}
33
34QString frmMain::getXorEncryptDecrypt(const QString &data, char key)
35{
36    //采用异或加密,也可以自行更改算法
37    QByteArray buffer = data.toLatin1();
38    int size = buffer.size();
39    for (int i = 0; i < size; i++) {
40        buffer[i] = buffer.at(i) ^ key;
41    }
42
43    return QLatin1String(buffer);
44}
45
46void frmMain::on_btnOk_clicked()
47{
48    bool useDate = ui->ckDate->isChecked();
49    bool useRun = ui->ckRun->isChecked();
50    bool useCount = ui->ckCount->isChecked();
51
52    if (!useDate && !useRun && !useCount) {
53        if (QMessageBox::question(this, "询问", "确定要生成没有任何限制的密钥吗?") != QMessageBox::Yes) {
54            return;
55        }
56    }
57
58    QString strDate = ui->dateEdit->date().toString("yyyy-MM-dd");
59    QString strRun = ui->cboxMin->currentText();
60    QString strCount = ui->cboxCount->currentText();
61    QString key = QString("%1|%2|%3|%4|%5|%6").arg(useDate).arg(strDate).arg(useRun).arg(strRun).arg(useCount).arg(strCount);
62
63    QFile file(QApplication::applicationDirPath() + "/key.db");
64    file.open(QFile::WriteOnly | QIODevice::Text);
65    file.write(getXorEncryptDecrypt(key, 110).toLatin1());
66    file.close();
67    QMessageBox::information(this, "提示", "生成密钥成功,将 key.db 文件拷贝到对应目录即可!");
68}
69
70void frmMain::on_btnClose_clicked()
71{
72    this->close();
73}
  • MiniDump

  • 扩展库

  • 获取硬件信息
QString frmMain::getWMIC(const QString &cmd)
{//获取cpu名称:wmic cpu get Name//获取cpu核心数:wmic cpu get NumberOfCores//获取cpu线程数:wmic cpu get NumberOfLogicalProcessors//查询cpu序列号:wmic cpu get processorid//查询主板序列号:wmic baseboard get serialnumber//查询BIOS序列号:wmic bios get serialnumber//查看硬盘:wmic diskdrive get serialnumberQProcess p;p.start(cmd);p.waitForFinished();QString result = QString::fromLocal8Bit(p.readAllStandardOutput());QStringList list = cmd.split(" ");result = result.remove(list.last(), Qt::CaseInsensitive);result = result.replace("\r", "");result = result.replace("\n", "");result = result.simplified();return result;
}
QString frmMain::getCpuName()
{return getWMIC("wmic cpu get name");
}
QString frmMain::getCpuId()
{return getWMIC("wmic cpu get processorid");
}
QString frmMain::getDiskNum()
{return getWMIC("wmic diskdrive where index=0 get serialnumber");
}
  • QProcess使用
bat进程启动运行QProcess process;
process.start("del /s *.txt");
// same as process.start("del", QStringList() << "/s" << "*.txt");空格不用管在要执行的路径前和后加上双引号就可以。
比如process.start("D:\Program Files\XiaZaiBa.exe");
写成process.start("\"D:\Program Files\XiaZaiBa.exe\"");就可以了。process.setWorkingDirectory( "./subdir" );  process.start( QApplication::applicationDirPath() + "subdir/sub.exe" );  不用vbs的bat启动,给入监控端口参数启动QProcess process; QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); 
env.insert("TMPDIR", "C:\\MyApp\\temp"); // Add an environment variable 
process.setProcessEnvironment(env); 
process.start("myapp");//启用VBS脚本
wscript.exe//system("WScript.exe  ../engine/HideRun.vbs");SHELLEXECUTEINFOA ShExecInfo;ShExecInfo.cbSize = sizeof(SHELLEXECUTEINFOA);ShExecInfo.fMask = SEE_MASK_NOCLOSEPROCESS;ShExecInfo.hwnd = NULL;ShExecInfo.lpVerb = NULL;ShExecInfo.lpFile = "I:/QTCreator/meidayunpan/prj_meida/git_lsx/MideaDisk/engine/aria2c.exe";ShExecInfo.lpParameters = "--conf-path=aria2.conf";//传出去的参数ShExecInfo.lpDirectory = NULL;ShExecInfo.nShow = SW_SHOW;ShExecInfo.hInstApp = NULL;BOOL b_ret = ShellExecuteExA(&ShExecInfo);QProcess* process = new QProcess(this);process->start("../engine/aria2c.exe", QStringList() << "--conf-path=aria2.conf");QObject::connect(process, SIGNAL(errorOccurred(QProcess::ProcessError)), this, SLOT([&](QProcess::ProcessError){switch (error){case QProcess::FailedToStart:QMessageBox::information(0, "FailedToStart", "FailedToStart");break;case QProcess::Crashed:QMessageBox::information(0, "Crashed", "Crashed");break;case QProcess::Timedout:QMessageBox::information(0, "FailedToStart", "FailedToStart");break;case QProcess::WriteError:QMessageBox::information(0, "Timedout", "Timedout");break;case QProcess::ReadError:QMessageBox::information(0, "ReadError", "ReadError");break;case QProcess::UnknownError:QMessageBox::information(0, "UnknownError", "UnknownError");break;default:QMessageBox::information(0, "default", "default");break;}}));//启动QObject::connect(process, SIGNAL(started()), this, SLOT([&](){QMessageBox::information(0, "start", "start");}));//状态改变QObject::connect(process, SIGNAL(stateChanged(QProcess::ProcessState)), this, SLOT([&](QProcess::ProcessState newState){QMessageBox::information(0, "startChange", QString::number(newState));}));//退出QObject::connect(process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT([&](int exitCode, QProcess::ExitStatus exitStatus){QMessageBox::information(0, QString::number(exitCode), QString::number(exitStatus));}));
  • 界面美化

  • 自定义皮肤

  • Qt最小化后恢复界面假死冻结
void showEvent(QShowEvent *e){
setAttribute(Qt::WA_Mapped);
QWidget::showEvent(e);
}
  • QML加载
m_pQuickWidget = new QQuickWidget(this);
m_pQuickWidget->setFixedSize(1131,586);
m_pQuickWidget->setAttribute(Qt::WA_AlwaysStackOnTop);
m_pQuickWidget->setClearColor(QColor(Qt::transparent));
m_pQuickWidget->setSource(QUrl(QStringLiteral("qrc:/UI/Viewer.qml")));
m_pQuickWidget->rootObject()->setWidth(1131);
m_pQuickWidget->rootObject()->setHeight(586);
m_pQuickWidget->move(this->width()/2.0 - m_pQuickWidget->width()/2.0,342);
m_pQuickWidget->show();
  • 内存SQL
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName(":memory:");
  • http服务器

  • 大师

  • Z-order assignment  is not a valid widget

用记事本打开对应的ui文件,找到为空的地方,删除即可

  • 常见问题
图片访问,需编辑qrc文件,添加资源,使用:/全路径名访问。
Vs下qt/Qt setting选择项添加相应模块
QPalette::Window表示背景色,QPalette::WindowText表示前景色
qmake -tp vc,qt工程转vc工程,同理,vs下qt选项也可以转qt工程
无法打开stddef与corecrt等文件,需要安装win kits 10 sdk,配置pro目录。或者直接使用vs2017安装更新vs sdk
Qml计时:console.time()  console.endtime()\
Qmake执行失败,路径必须为全英文
类成员线程快速创建,头文件QtConcurrentrun,命名空间QtConcurrent::run
编码换行符错误:
QTextCodec *codec = QTextCodec::codecForName("UTF-8");//情况2
QTextCodec::setCodecForTr(codec);
QTextCodec::setCodecForLocale(codec);
QTextCodec::setCodecForCStrings(codec);
选项/设置/文本编辑:主要是设置成UTF-8格式,再把BOM设置成都添加。
10.构造与析构函数无法解析,执行qmake
  • 指示器样式
例如 ::down-arrow,::menu-indicator{} ::up-arrow:disabled,::up-arrow:off{}。
  • 管理员运行
QMAKE_LFLAGS += /MANIFESTUAC:\"level=\'requireAdministrator\' uiAccess=\'false\'\" #以管理员运行
QMAKE_LFLAGS += /SUBSYSTEM:WINDOWS,\"5.01\" #VS2013 在XP运行
  • 标题栏高度
style()->pixelMetric(QStyle::PM_TitleBarHeight); PM_TitleBarHeight点进去你会发现新大陆
  • 获取类属性

const QMetaObject *metaobject = object->metaObject();
int count = metaobject->propertyCount();
for (int i = 0; i < count; ++i) {
QMetaProperty metaproperty = metaobject->property(i);
const char *name = metaproperty.name();
QVariant value = object->property(name);
qDebug() << name << value;
}
  • 每个控件都有ID
a.setAttribute(Qt::AA_NativeWindows);可以让每个控件都拥有独立的句柄。
  • 2K,4K屏支持
#if (QT_VERSION > QT_VERSION_CHECK(5,6,0))
QGuiApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
#endif
  • 线程

QThread用法:启动与退出_qthread restart-CSDN博客

http://m.codes51.com/itwd/1338157.html

QT:最简单的方法实现多线程_正在拉磨_新浪博客

Qt使用多线程的一些心得_qt emit 处理时间长-CSDN博客

QT:最简单的方法实现多线程_正在拉磨_新浪博客

  • 换肤
//移除原有样式
style()->unpolish(ui->btn);
//重新设置新的该控件的样式。
style()->polish(ui->btn);
  • webengine模块发布
发布程序的时候带上QtWebEngineProcess.exe+translations文件夹+resources文件夹
  • 启用独立控制台
运行文件附带调试输出窗口 CONFIG += console pro
  • 中文编译乱码
#if _MSC_VER >= 1600
#pragma execution_character_set("utf-8")
#endifQt creator 的菜单里 编辑-Select Encoding,可以选择编码。以及工具-选项->文本编辑器->行为->文件编码里要选择UTF-8,BOM: 如果是UTF-8则自动添加。QString::fromLocal8Bit
  • 重复文件保存
QString path = "F:/down/";
QFile m_saveFile(path + strFileName);
int i = 1;
while (m_saveFile.exists()) {m_saveFile.setFileName(path + strFileName + QString::number(i));++i;
}
int indexPt = strFileName.lastIndexOf('.');
path.append(strFileName.mid(0, indexPt));
path.append(QString::number(i));
path.append(strFileName.mid(indexPt, strFileName.length() - indexPt));
m_saveFile.setFileName(path);if (m_saveFile.open(QIODevice::WriteOnly))
{	//打开失败m_saveFile.write(stuBytes.m_pChar, stuBytes.m_size);m_saveFile.close();
}

QT实现windows窗口内嵌_qt dialog窗口嵌入在主窗口内部-CSDN博客 

QT样式美化 之 qss入门_qt tablewidget qss-CSDN博客

C++ QT实现验证码功能_qt中实现手机验证码的方法-CSDN博客

C++ 仿QT信号槽二-CSDN博客

C++ 实现QT信号槽_c++ 加qt写一个好的示波器-CSDN博客

Electron qt开发教程_qt electron混合开发-CSDN博客


创作不易,小小的支持一下吧!

相关文章:

QT 笔记

HTTPS SSL配置 下载配置 子父对象 QTimer *timer new QTimer; // QTimer inherits QObject timer->inherits("QTimer"); // returns true timer->inherits("QObject"); // returns true timer->inherits("QAbst…...

【redis 第七篇章】动态字符串

一、概述 string 类型底层实现的简单动态字符串 sds&#xff0c;是可以修改的字符串。它采用预分配冗余空间的方式来减少内存的频繁分配。 二、SDS动态字符串 动态字符串 是以 \0 为分隔符。最大容量 是 redis 主动分配的一块内存空间&#xff0c;实际存储内容 是具体的存的数…...

rk3588 部署yolov8.rknn

本文从步骤来记录在rk3588芯片上部署yolov8模型 主机&#xff1a;windows10 VMware Workstation 16 Pro 硬件&#xff1a;RK3588 EVB板 模型&#xff1a; RK3588.rknn 软件开发环境&#xff1a; c cmake step1: 主机上执行&#xff1a; 将rknn_model_zoo 工程文件下载…...

【正点原子i.MX93开发板试用连载体验】中文提示词的训练

本文首发于电子发烧友论坛&#xff1a;【正点原子i.MX93开发板试用连载体验】基于深度学习的语音本地控制 - 正点原子学习小组 - 电子技术论坛 - 广受欢迎的专业电子论坛! 好久没有更新了&#xff0c;今天再来更新一下。 我们用前面提到的录音工具录制了自己的中文语音&#…...

WordPress资源下载类主题 CeoMax-Pro_v7.6绕授权开心版

CeoMax-Pro强大的功能 在不久的将来Ta能实现你一切幻想&#xff01;我们也在为此而不断努力。适用于资源站、下载站、交易站、素材站、源码站、课程站、cms等等等等&#xff0c;Ta 为追求极致的你而生。多风格多样式多类型多行业多功能 源码下载&#xff1a;ceomax-pro7.6.zip…...

使用GCC编译Notepad++的插件

Notepad的本体1是支持使用MSVC和GCC编译的2&#xff0c;但是Notepad插件的官方文档3里却只给出了MSVC的编译指南4。 网上也没有找到相关的讨论&#xff0c;所以我尝试在 Windows 上使用 MinGW&#xff0c;基于 GCC-8.1.0 的 posix-sjlj 线程版本5&#xff0c;研究一下怎么编译…...

技术周总结 2024.07.29 ~ 08.04周日(MyBatis, 极限编程)

文章目录 一、08.01 周四1.1&#xff09;mybatis的 xml文件中的 ${var} 和 #{var}的区别&#xff1f; 二、08.03 周六2.1&#xff09;极限编程核心价值观核心实践实施极限编程的好处极限编程的挑战适用场景 三、08.04 周日3.1&#xff09;《计算机信息系统安全保护等级划分准则…...

C语言调试宏全面总结(六大板块)

C语言调试宏进阶篇&#xff1a;实用指南与案例解析C语言调试宏高级技巧与最佳实践C语言调试宏的深度探索与性能考量C语言调试宏在嵌入式系统中的应用与挑战C语言调试宏在多线程环境中的应用与策略C语言调试宏在并发编程中的高级应用 C语言调试宏进阶篇&#xff1a;实用指南与案…...

unity万向锁代数法解释

unity的矩阵旋转乘法顺序是yxz 旋转x的90度的矩阵: 1 0 0 0 0 -1 0 1 0旋转y和z的矩阵假设角度为y和z&#xff0c;矩阵略不写了 按顺序乘完yxz之后结果是 cos(y-z) sin(y-z) 0 0 0 -1 -sin(y-z) cos(y-z) 0这个结果和Rx(pi/2) *Rz(某个角度)的结果是一个形式&#xff0c;Rx和…...

stm32入门学习10-I2C和陀螺仪模块

&#xff08;一&#xff09;I2C通信 &#xff08;1&#xff09;通信方式 I2C是一种同步半双工的通信方式&#xff0c;同步指的是通信双方时钟为一个时钟&#xff0c;半双工指的是在同一时间只能进行接收数据或发送数据&#xff0c;其有一条时钟线&#xff08;SCL&#xff09;…...

GDB常用指令

GDB调试&#xff1a;GDB调试的是可执行文件&#xff0c;在gcc编译时加入-g参数&#xff0c;告诉gcc在编译时加入调试信息&#xff0c;这样gdb才能调试这个被编译的文件。此外还会加上-Wall参数尽量显示所有警告信息。 GDB命令格式&#xff1a; 1、start&#xff1a;程序在第一…...

Nginx 高级 扩容与高效

Nginx高级 第一部分&#xff1a;扩容 通过扩容提升整体吞吐量 1.单机垂直扩容&#xff1a;硬件资源增加 云服务资源增加 整机&#xff1a;IBM、浪潮、DELL、HP等 CPU/主板&#xff1a;更新到主流 网卡&#xff1a;10G/40G网卡 磁盘&#xff1a;SAS(SCSI) HDD&#xff08;机械…...

pythonflaskMYSQL自驾游搜索系统32127-计算机毕业设计项目选题推荐(附源码)

目 录 摘要 1 绪论 1.1研究背景 1.2爬虫技术 1.3flask框架介绍 2 1.4论文结构与章节安排 3 2 自驾游搜索系统分析 4 2.1 可行性分析 4 2.2 系统流程分析 4 2.2.1数据增加流程 5 2.3.2数据修改流程 5 2.3.3数据删除流程 5 2.3 系统功能分析 5 2.3.1 功能性分析 6 2.3.2 非功…...

C++ vector的基本使用(待补全)

std::vector 是C标准模板库(STL)中的一个非常重要的容器类&#xff0c;它提供了一种动态数组的功能。能够存储相同类型的元素序列&#xff0c;并且可以自动管理存储空间的大小&#xff0c;以适应序列大小变化&#xff0c;处理元素集合的时候很灵活 1. vector的定义 构造函数声…...

Java 属性拷贝 三种实现方式

第一种 List<OrederPayCustomer> orederPayCustomerList this.list(queryWrapper); List<CustomerResp>customerRespListnew ArrayList<>();for (OrederPayCustomer orederPayCustomer : orederPayCustomerList) {CustomerResp customerResp new Custome…...

Java-变量,运算符,输入与输出

目录 一&#xff0c;语法基础 1.基本Java程序 2.语法基础 2.1 变量 2.2 常量限制(fiinal)类比C中的const 2.3 类型转化 2.4 运算符 2.5 表达式 2.5 输入与输出 2.5.1 输入 2.5.2 输出 一&#xff0c;语法基础 1.基本Java程序 public class Main{public static void…...

五、一个quad同时支持pcie和sfp两种高速接口的ref时钟配置

项目描述 上位机将截图数据通过 XDMA 写入到 FPGA 侧的 DDR 内存区域 1 中通过 axi_lite 接口给 axi_read_start 信号&#xff0c;通知 AXI_read 模块启动读取数据&#xff0c;然后通过 GTP TX 模块发送出去。经过光纤回环&#xff0c;GTP RX 端接收到数据&#xff0c;送给 AX…...

AI辅助教育:九章大模型的数学辅导功能解析

1.简介 九章大模型是学而思为学习研发的模型&#xff0c;该模型对于数学做了很多专门的训练&#xff0c;在题目推荐方面做得比较好。 同时&#xff0c;这个模型也能支持上传图片&#xff0c;对图片内容进行分析&#xff0c;然后针对内容进行校对&#xff0c;推荐相识题目。 支…...

力扣刷题之3128.直角三角形

题干描述 给你一个二维 boolean 矩阵 grid 。 请你返回使用 grid 中的 3 个元素可以构建的 直角三角形 数目&#xff0c;且满足 3 个元素值 都 为 1 。 注意&#xff1a; 如果 grid 中 3 个元素满足&#xff1a;一个元素与另一个元素在 同一行&#xff0c;同时与第三个元素…...

OD C卷 - 机场航班调度

机场航班调度&#xff08;100&#xff09; 航班组成&#xff1a;前两个大写字母代表航空公司缩写&#xff0c;后面4个数字代表航班信息&#xff1b;对输入的航班排序 首先按照航空公司缩写升序排序&#xff1b;同一航空公司的按照航班信息升序排序&#xff1b; 输入描述&…...

uni-app中使用支付宝扫码插件并且在真机调试时使用(详细教程)

前言&#xff1a;uni-app自带的扫码api 识别不灵敏&#xff0c;每次都得扫很长时间且不断调整才能扫出来码&#xff0c;所以决定使用支付宝扫码插件&#xff0c;官方插件地址&#xff1a;https://ext.dcloud.net.cn/plugin?id2636#detail 使用步骤: 1、下载插件到项目中 2、…...

每日学术速递8.5—1

1.SV4D: Dynamic 3D Content Generation with Multi-Frame and Multi-View Consistency 标题&#xff1a; SV4D&#xff1a;具有多帧和多视图一致性的动态 3D 内容生成 作者&#xff1a;Yiming Xie, Chun-Han Yao, Vikram Voleti, Huaizu Jiang, Varun Jampani 文章链接&…...

1、操作系统相关概念

1、操作系统是计算机上的第一层软件&#xff0c;用于管理计算机硬件设备&#xff0c;提高他们的利用率和通吐量&#xff0c;并为用户和应用程序提供一个接口。不同操作系统目标不同&#xff0c;查询设备的操作系统&#xff0c;侧重人机交互性&#xff1b;武器控制操作系统&…...

【ModelSim】仿真问题记录

1、波形出不全&#xff1a; 1、甚至连clk波形都出不来 2、个别波形只有到仿真结束的时候才出现 解决办法&#xff1a; 1、添加波形需要是实例中的net 2、排查是否存在声明与示例的位宽不一致的信号 3、观察是否存在未初始化的变量寄存器 4、缩短整个仿真的步长 2、Instance列…...

如何提高深度学习中数据运行的稳定性

在深度学习中&#xff0c;模型的训练通常会受到随机性因素的影响&#xff0c;如参数初始化、数据加载顺序等。这会导致每次训练得到的结果有所不同。要减少这种不稳定性&#xff0c;可以采取以下措施&#xff1a; 1.固定随机种子 通过设置随机种子&#xff0c;可以使得每次训…...

【连续数组】python刷题记录

R3-前缀和专题 绝对要用字典记录 ben神&#xff0c;前缀和字典 class Solution:def findMaxLength(self, nums: List[int]) -> int:#前缀和字典,key为差值&#xff0c;value为坐标dict{0:-1}#当前1和0的差值counter0ret0for i,num in enumerate(nums):#多1&#xff0b;1if…...

JavaScript青少年简明教程:DOM和CSS简介

JavaScript青少年简明教程&#xff1a;DOM和CSS简介 DOM简介 DOM&#xff08;Document Object Model&#xff09;将文档表示为一个树形结构&#xff0c;其中每个节点都是一个对象&#xff0c;每个对象都有其自身的属性和方法。 通过对DOM的操作&#xff0c;开发者可以使用编…...

架构师知识梳理(一):计算机硬件

目录 计算机硬件组成 CPU CPU的组成 CPU的功能 校验码 奇偶校验 CRC CRC计算案例 指令 指令指行过程 指令系统 指令系统分类 指令流水线技术 流水线技术相关计算公式 存储 计算机存储系统设计 高速缓存Cache 缓存的局部性原理 地址映射 替换算法 关于命中…...

从根儿上学习spring 四 之run方法启动第一段

图1 由上图我们可以看到&#xff0c;我把run方法分成了5个小段&#xff0c;每小段使用红框圈了起来&#xff0c;这一篇我们先开始讲第一段。大家需要关注下行号&#xff0c;我讲的时候可能会使用行号对应具体某行代码。 图1-289-290行&#xff1a; 没啥好说的定义了两个变量&…...

智能闹钟如何判断用户已经醒了?

智能闹钟判断用户是否已经醒来的方式主要依赖于其内置的传感器和算法系统。以下是一些常见的判断方法&#xff1a; 一、传感器监测 体动传感器&#xff1a;智能闹钟通常配备有体动传感器&#xff0c;用于监测用户的身体运动。当用户从睡眠状态转变为清醒状态&#xff0c;并开始…...