QT namespace 问题!!!

namespace Ui{
class MainWindow;
}

Ui:: MainWindow *ui;

ui(new Ui::MainWindow),

ui->setupUi(this);

同样的四段代码。QT运行就正常,VS插件QT就报错(不允许使用不完整的类型)。

VS方式是:

Ui::MainWindow Class ui;
ui.setupUi(this);

大牛帮我详细的讲解一下。万分感谢!!!

1个回答

Qt库没正常加载进去吧,dll lib等等环境都设置好了么?都检查下

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
急!!!Linux编译死锁多线程在qt中报错!求大神指点!!
在qt里写的死锁多线程,但是一直报错error: collect2: error: ld returned 1 exit status; qt菜鸟感觉自己没哪里写错了,于是死都看不出bug在哪,快要die了 ``` //Pthread.h #include <QThread> #include <QDebug> class Pthread1: public QThread { Q_OBJECT protected: //线程退出的标识量 volatile bool m_stop; void run(); signals: void send_signal(int);//自定义信号 public: Pthread1(); ~Pthread1(); void stop();//线程退出的接口函数,用户使用 }; class Qthread1: public QThread { Q_OBJECT protected: //线程退出的标识量 volatile bool m_stop; void run(); signals: void send_signal(int);//自定义信号 public: Qthread1(); ~Qthread1(); void stop();//线程退出的接口函数,用户使用 }; //Pthread.cpp #include "Pthread1.h" #include <QMutex> #include <unistd.h> //用于sleep QMutex MutexA; QMutex MutexB; Pthread1::Pthread1(){ m_stop = false; } Pthread1::~Pthread1(){ } void Pthread1::stop(){ m_stop = true; } void Pthread1::run(){ int step = 0; while(!m_stop) { MutexA.lock(); step = 1; emit send_signal(step); sleep(1000); MutexB.lock(); step = 3; emit send_signal(step); MutexA.unlock(); step = 4; emit send_signal(step); msleep(1); MutexB.unlock(); step = 5; emit send_signal(step); msleep(1); } m_stop = 0; } Qthread1::Qthread1(){ m_stop = false; } Qthread1::~Qthread1(){ } void Qthread1::stop(){ m_stop = true; } void Qthread1::run(){ int step = 0; while(!m_stop) { MutexB.lock(); step = 2; emit send_signal(step); sleep(1000); MutexA.lock(); step = 6; emit send_signal(step); MutexB.unlock(); step = 7; emit send_signal(step); msleep(1); MutexA.unlock(); step = 8; emit send_signal(step); msleep(1); } m_stop = 0; } //MainWindow.h namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0, Qt::WindowFlags flags = 0); ~MainWindow(); private: Ui::MainWindow *ui; Pthread1 *p1; Qthread1 *q1; public slots: void send_cmd(int); void lock(); void unlock(); }; //MainWindow.cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <qmessagebox.h> #include <semaphore.h> #include <stdio.h> #include <string.h> #include <stdlib.h> #include <unistd.h> //用于sleep using namespace std; MainWindow::MainWindow(QWidget *parent, Qt::WindowFlags flags) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); p1 = new Pthread1; q1 = new Qthread1; connect(ui->pushButton_2_1_b,SIGNAL(clicked()),this,SLOT(lock())); connect(p1,SIGNAL(send_signal(int )),this,SLOT(send_cmd(int )),Qt::BlockingQueuedConnection); connect(q1,SIGNAL(send_signal(int )),this,SLOT(send_cmd(int )),Qt::BlockingQueuedConnection); } MainWindow::~MainWindow() { delete ui; } void MainWindow::send_cmd(int step){ if(step == 1){ //P1 get mutexA QPropertyAnimation *animation = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation->setDuration(1000); animation->setStartValue(QRect(530,140,141,71)); animation->setEndValue(QRect(250,420,141,71)); animation->start(); } else if(step == 2){ //Q1 get mutexB QPropertyAnimation *animation1 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation1->setDuration(1000); animation1->setStartValue(QRect(670,210,141,71)); animation1->setEndValue(QRect(110,420,141,71)); animation1->start(); } else if(step == 3){ //P2 release mutexA QPropertyAnimation *animation3 = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation3->setDuration(1000); animation3->setStartValue(QRect(250,420,141,71)); animation3->setEndValue(QRect(390,420,141,71)); animation3->start(); QPropertyAnimation *animation4 = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation4->setDuration(1000); animation4->setStartValue(QRect(390,420,141,71)); animation4->setEndValue(QRect(390,280,141,71)); animation4->start(); } else if(step == 4){ //P2 get mutexB QPropertyAnimation *animation5 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation5->setDuration(1000); animation5->setStartValue(QRect(530,210,141,71)); animation5->setEndValue(QRect(530,420,141,71)); animation5->start(); } else if(step == 5){ //P2 release mutexB QPropertyAnimation *animation6 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation6->setDuration(1000); animation6->setStartValue(QRect(530,420,141,71)); animation6->setEndValue(QRect(670,420,141,71)); animation6->start(); QPropertyAnimation *animation7 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation7->setDuration(1000); animation7->setStartValue(QRect(670,420,141,71)); animation7->setEndValue(QRect(670,210,141,71)); animation7->start(); } else if(step == 6){ //Q2 get mutexA QPropertyAnimation *animation9 = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation9->setDuration(1000); animation9->setStartValue(QRect(390,280,141,71)); animation9->setEndValue(QRect(110,280,141,71)); animation9->start(); } else if(step == 7){ //Q2 release mutexB QPropertyAnimation *animation10 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation10->setDuration(1000); animation10->setStartValue(QRect(110,420,141,71)); animation10->setEndValue(QRect(110,210,141,71)); animation10->start(); QPropertyAnimation *animation11 = new QPropertyAnimation(ui->pushButton_2_1_2,"geometry"); animation11->setDuration(1000); animation11->setStartValue(QRect(110,210,141,71)); animation11->setEndValue(QRect(530,210,141,71)); animation11->start(); } else if(step == 8){ //Q2 release mutexA QPropertyAnimation *animation12 = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation12->setDuration(1000); animation12->setStartValue(QRect(110,280,141,71)); animation12->setEndValue(QRect(110,140,141,71)); animation12->start(); QPropertyAnimation *animation13 = new QPropertyAnimation(ui->pushButton_2_1_1,"geometry"); animation13->setDuration(1000); animation13->setStartValue(QRect(110,140,141,71)); animation13->setEndValue(QRect(530,140,141,71)); animation13->start(); } } void MainWindow::lock(void) { q1->start(); p1->start(); q1->stop(); p1->stop(); q1->wait(); p1->wait(); } ``` 顺便想问一句,怎样在qt里一次创建多个线程就像Thread[ ]类似数组那样!!!
QT程序移植,编译后出现 using namespace std::tr1; 存在问题无法得到解决
同上,QT程序移植,编译后出现 using namespace std::tr1; 存在问题无法得到解决 ,报错见图片 说 str1不是命名好像
qt和vs2015新建ui的命名空间的问题
在qt和vs2015 的里面新加一个ui的时候,进行编译的时,会出现ui_XXXX文件的里面的编译出来的命名空间 的名字相同的问题,可以在变异的时候让不同的ui编译出来的ui_XXX的命名空间是不一样的吗 现在的命名空间是namespace Ui { class Form: public Ui_Form {};} 希望大神可以指导一下。 再生成的ui里面直接修改namespace的话,重新编译的时候还是会再次修改回去,重命名的话,是对ui文件进行修改吗 ?
qt 很简单的一段代码 利用Qsetting 完成,但是在读取配置文件的时候,出问题
``` #include "widget.h" #include "ui_widget.h" #include<QTime> #include<iostream> #include<QString> #include<QSettings> #include<QDebug> #include<QFile> #include <QMessageBox> #include <QDir> #include<QFileDialog> #define CONFIG_FILE "config.ini" using namespace std; Widget::Widget(QWidget *parent) : QWidget(parent) , ui(new Ui::Widget) { ui->setupUi(this); QSettings *configIniRead = new QSettings("config.ini", QSettings::IniFormat); //在堆里面开辟了一块区域,然后把地址赋给栈中的某个地址 dir_src = configIniRead->value("main/bak_src").toString();// value 是Qsetting里面的公开方法 cout << "当前目录为:" <<dir_src.toLocal8Bit().data(); dir_dest = configIniRead->value("main/bak_dest").toString(); // 配置文件里面有目标地址 gpg_key = configIniRead->value("main/gpg_key").toString(); exclude_from = configIniRead->value("exclude/exclude").toString(); delete configIniRead; // 与初始化的对象成对出现,会造成内存泄漏 ui->lineEdit->setText(dir_src); } Widget::~Widget() { delete ui; } ``` 上面是cpp里面的 ``` #ifndef WIDGET_H #define WIDGET_H #include <QWidget> QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACE class Widget : public QWidget { Q_OBJECT public: Widget(QWidget *parent = nullptr); ~Widget(); private: Ui::Widget *ui; QString dir_src; QString dir_dest; QString dir_restore; QString gpg_key; QString arc_user; QString arc_path; QString exclude_from; }; #endif // WIDGET_H ``` 上面是h文件里面的 ``` [exclude] exclude=--exclude *.iso --exclude .gvfs/** --exclude .thumbnails/** --exclude .trash/** --exclude .Trash/** --exclude *-gitsvn/** --exclude *-cvs/** --exclude *-svn/** --exclude *-git/** --exclude *-sf/** --exclude *.vc --exclude *.tc --exclude .cache/** --exclude .ccache/** --exclude ./Downloads/** --exclude ./.wine/** --exclude ./Documents/Dropbox/** [main] arc_path=bak_lg arc_user=testuser bak_dest=/home/hu/backup bak_src=/home/hu/retore gpg_key=xujing113221@hotmail.com last_time=1572976195 ``` 上面是配置文件 我在读取配置文件下面做了一个输出,但是就是没有任何输出,我之后在后面加了字符串,发现有了输出,说明是配置文件没有被读出来 于是我改了配置文件的权限是 777,但是还是没有输出 最后我实在受不了,就重新建立一个项目尝试了一下,还是一点反应都没有 配置文件所在目录 就是h文件和cpp文件所在的目录
QT使用std::unordered_map时报错:the code model could not parse an included file, which might lead to incorrect code completion and highlighting
编译时报大量的这种错误:<br><br> ![图片说明](https://img-ask.csdn.net/upload/201912/27/1577439228_688736.png) <br> <br> 已把无关的代码注释省略了: <br> <br> ``` #ifndef APROCHDATAMODELREGISTRY_H #define APROCHDATAMODELREGISTRY_H // #include ... #include <memory> #include <utility> #include <functional> #include <QString> // 只要包含这个文件,就会报错,但不包含就无法使用unordered_map #include <unordered_map> APROCH_NAMESPACE_BEGIN class APROCH_EXPORT AprochDataModelRegistry { public: using RegisteredModelsCategoryMap = std::unordered_map<QString, QString>; // ... private: RegisteredModelsCategoryMap mRegisteredModelsCategory; // ... }; APROCH_NAMESPACE_END #endif // APROCHDATAMODELREGISTRY_H ```
Qt tr()翻译 加载 问题
关于Qt 多语言的问题 加载qm时,有些没有翻译过来,显示的还是原本的! 是这样的,我想把所有成员变量写在一个类中,这些成员变量是公共 的,供其它类来访问修改,那么问题来了:在其它类中调用全局变量或全局类后翻译后,加载时没有翻译过来,都保持了原样; 网上说的大部分资料我都看过,大部分针对的是乱码问题,对于我这种形式的介绍的比较少,我不知道怎么办,所以来求助各位大侠: 代码抽出来了,简化成以下示例: test.pro: ``` QT += core gui TARGET = Test TEMPLATE = app SOURCES += main.cpp test.cpp global.cpp HEADERS += test.h global.h FORMS += test.ui TRANSLATIONS = test.ts RESOURCES += test.qrc ``` 全局类: **global.h:** ``` #ifndef GLOBAL_H #define GLOBAL_H #include <QString> class Global { public: Global(); QString strTest; }; **global.cpp:** extern Global myGlobal; #endif // GLOBAL_H #include "global.h" #include <QObject> Global myGlobal; Global::Global() { strTest = QObject::tr("Text"); }; ``` 测试类: **test.h:** ``` #ifndef TEST_H #define TEST_H #include <QDialog> namespace Ui { class Test; } class Test : public QDialog { Q_OBJECT public: explicit Test(QWidget *parent = 0); ~Test(); private: Ui::Test *ui; }; #endif // TEST_H ``` **test.cpp:** ``` #include "test.h" #include "ui_test.h" #include "global.h" Test::Test(QWidget *parent) : QDialog(parent), ui(new Ui::Test) { ui->setupUi(this); //文字还是翻译前的,没有进行更新: ui->lbTest->setText(myGlobal.strTest); //如果定义一个局部变量,是可以成功显示翻译后的文本,但是这样没用呀,因为这个类变量要是全局的,其它类也要访问和修改: //Global test; //ui->lbTest->setText(test.strTest); } Test::~Test() { delete ui; } ``` **test.ui:**就加一个标签控件,用于显示文本 ``` <?xml version="1.0" encoding="UTF-8"?> <ui version="4.0"> <class>Test</class> <widget class="QDialog" name="Test"> <property name="geometry"> <rect> <x>0</x> <y>0</y> <width>400</width> <height>300</height> </rect> </property> <property name="windowTitle"> <string>Test</string> </property> <layout class="QGridLayout" name="gridLayout"> <item row="0" column="0"> <widget class="QLabel" name="lbTest"> <property name="text"> <string/> </property> <property name="alignment"> <set>Qt::AlignCenter</set> </property> </widget> </item> </layout> </widget> <layoutdefault spacing="6" margin="11"/> <resources/> <connections/> </ui> ``` **Main.cpp:** ``` #include <QtGui/QApplication> #include "test.h" #include <QTextCodec> #include <QTranslator> QTranslator *myTranslator; int main(int argc, char *argv[]) { QApplication a(argc, argv); myTranslator = new QTranslator(); myTranslator->load(":/test.qm"); a.installTranslator(myTranslator); Test w; w.show(); return a.exec(); } ``` 用Qt Linguist 将文本“Text”翻译成“Update Text”: 编译运行,没有变化,显示的还是原“Text”! 如果在test类中定义局部变量,就会成功,显示的是翻译后的(但是局部的没用,不是我想要的,我需要的是全局的): 期间: 文件编码用GB2312和UTF-8都试过,翻译都无效! tr编码用GB2312和UTF-8都试过,翻译也都无效! 头疼呀 ,请各位大侠赐教,谢谢!
关于Qt弹出的窗口闪退的问题
_(:з」∠)_本人新手,前两天刚刚接触了Qt,今天想试试能不能做出弹出窗口,很幸运,成功弹出窗口,不过不知道为啥窗口刚刚出现就消失了,,,有没有大神可以帮下忙呢~~~谢谢啦,第一次发帖。。。。 dialog.h文件: ``` #ifndef DIALOG_H #define DIALOG_H #include <QDialog> #include<QLabel> namespace Ui { class Dialog; } class Dialog : public QDialog { Q_OBJECT public: explicit Dialog(QWidget *parent = 0); ~Dialog(); private: Ui::Dialog *ui; QLabel *label; }; #endif // DIALOG_H ``` mainwindow.h文件: ``` #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private: Ui::MainWindow *ui; private slots: void push(); }; #endif // MAINWINDOW_H ``` main.cpp文件: ``` #include "mainwindow.h" #include <QApplication> #include "dialog.h" int main(int argc, char *argv[]) { QApplication a(argc, argv); MainWindow w; w.show(); return a.exec(); } ``` dialog.cpp文件: ``` #include "dialog.h" #include "ui_dialog.h" #include<QGridLayout> #include<windows.h> Dialog::Dialog(QWidget *parent) : QDialog(parent), ui(new Ui::Dialog) { ui->setupUi(this); label = new QLabel("label1"); QGridLayout *layout = new QGridLayout(this); // Sleep(5000); label->show(); // Sleep(5000); } Dialog::~Dialog() { // Sleep(5000); delete ui; } ``` mainwindow.cpp文件 ``` #include "mainwindow.h" #include "ui_mainwindow.h" #include"dialog.h" #include<QPushButton> #include<windows.h> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); connect(ui->button1,SIGNAL(clicked()),this,SLOT(push())); } MainWindow::~MainWindow() { delete ui; } int times=1; void MainWindow::push(){ for(long int i=0;i<times;i++) { QString temStr = ui->line->text(); times = temStr.toInt(); Dialog one; one.show(); } times = 1; } ``` 自己做了两个UI文件,觉得和问题没有太大的关联。
qt 运行出来的框图有残缺
# cpp文件 ``` #include "vsbak.h" #include "ui_vsbak.h" #include <QSettings> #include <QFileDialog> #include<QTime> #include<QtDebug> #include <QMessageBox> #define CONFIG_FILE "config.ini" const QString EXCLUDE_FILE = "/home/hu/project2";// 這個文件沒啥用 Vsbak::Vsbak(QWidget *parent) : QWidget(parent) , ui(new Ui::Vsbak) { ui->setupUi(this); QSettings *configIniRead = new QSettings(CONFIG_FILE, QSettings::IniFormat); dir_src = configIniRead->value("/main/bak_src").toString(); dir_dest = configIniRead->value("/main/bak_dest").toString(); // 配置文件里面有目标地址 gpg_key = configIniRead->value("/main/gpg_key").toString(); exclude_from = configIniRead->value("exclude/exclude").toString(); delete configIniRead; // init bash terminal //QProcess可以用于启动外部程序 cmd = new QProcess(this);// 因为与父类直接释放内存 // Sets the working directory to dir. QProcess will start the process in this directory. //The default behavior is to start the process in the working directory of the calling process. cmd->setWorkingDirectory(dir_src); //This signal is emitted when the process has made new data available //through its standard output channel (stdout). It is emitted regardless of the current read channel. connect(cmd, &QProcess::readyReadStandardOutput, this, &Vsbak::on_readyReadStandardOutput); connect(cmd, &QProcess::readyReadStandardError, this, &Vsbak::on_readyReadStandardError); ui->lineEdit->setText(dir_src); ui->lineEdit_2->setText(dir_dest); // 在ui里直接设置这个地址 // init comboBox init_comboBox(); // init radiobutton: choice full ui->radioButton->setChecked(true); ui->checkBox->setChecked(false); ui->checkBox_2->setEnabled(false); ui->checkBox_3->setEnabled(false); } /* * 设置最大可见数目为5,是不是不合理? */ void Vsbak::init_comboBox() // 找压缩好的文件 Combobox 下拉菜单 { /* * 1. 用一个对象进入dir-dest目录下 * 2. 过滤掉包含后追的文件 * 3. 获取被过滤的文件理解 */ // find all backup.tar.gz files //The QDir class provides access to directory structures and their contents. 不仅能看到结构,还可以看到目录 QDir *curDir = new QDir(dir_dest); //The QStringList class provides a list of strings. //可以让你提取一个新的列表只包含这些字符串包含一个特定的字符串(或匹配特定正则表达式) QStringList filter; // 过渡成一个目录 filter << "*.tar.gz" << "*.tar.gz.gpg"; curDir->setNameFilters(filter); // 过滤掉特定的目录下的文件 //Returns a list of QFileInfo objects for all the files and directories in the directory //QDir::entryInfoList()会获取该目录下所有目录和文件的QFileInfo对象的列表 QList<QFileInfo> *tarFileInfo = new QList<QFileInfo>(curDir->entryInfoList(filter)); /* * dir_dest 里面存放的其实都是被压缩的文件,所以用上面的后缀直接进行过滤 * 1. 设置最大的可见数目为5 * 2. 看目录里面有多少,然后放入这个comboBox * 3. 获取被过滤的文件 * 4. 按照顺序放入到combobox中 */ ui->comboBox->clear(); ui->comboBox->setMaxVisibleItems(5); // 最大可见数目 5 //The string will be inserted as the first item in the combobox. ui->comboBox->setInsertPolicy(QComboBox::InsertAtTop); for (int i=0; i< tarFileInfo->count(); i++)// count()只是计算里面的数量,tarFileinfo实际上是一个文件列表 ui->comboBox->addItem(tarFileInfo->at(i).fileName()); } Vsbak::~Vsbak() { delete ui; // 有何作用 if(cmd->state() == QProcess::Running){ cmd->terminate(); cmd->waitForFinished(); } } void Vsbak::on_readyReadStandardOutput() { // QString out = QString::fromLocal8Bit(cmd->readAllStandardOutput()); // ui->label_4->setText(out); } void Vsbak::on_readyReadStandardError() { QMessageBox::information(0, "Error", cmd->readAllStandardError()); } // change dir_src void Vsbak::on_toolButton_clicked() { /* * 1. 或许dir_src的文件目录名称 * 2. 将dir_src的文件目录名写到lineEdit上面 * 3. 更新配置文件里面的信息 * 4. 设置工作目录 * */ QString dirname; dirname = QFileDialog::getExistingDirectory(this, tr("Open Directory"), dir_src, QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks); if(dirname.isEmpty()) return; else { dir_src = dirname; ui->lineEdit->setText(dir_src); QSettings *configIniWrite = new QSettings(CONFIG_FILE, QSettings::IniFormat); configIniWrite->setValue("/main/bak_src", dir_src); delete configIniWrite; cmd->setWorkingDirectory(dir_src); ui->label_4->setText("change source dir sucess!"); } } // change dir_dest void Vsbak::on_toolButton_2_clicked() { QString dirname; // getExistingDirectory 只获取文件夹 dirname = QFileDialog::getExistingDirectory(this, tr("Open Directory"), dir_dest, QFileDialog::ShowDirsOnly | QFileDialog::DontResolveSymlinks); if(dirname.isEmpty()) return; else { dir_dest = dirname; ui->lineEdit_2->setText(dir_dest); QSettings *configIniWrite = new QSettings(CONFIG_FILE, QSettings::IniFormat); configIniWrite->setValue("/main/bak_dest", dir_dest); delete configIniWrite; ui->label_4->setText("change dest dir sucess!"); } } int Vsbak::get_min(QDateTime curTime) { QSettings *configIniReadWrite = new QSettings(CONFIG_FILE, QSettings::IniFormat); int lastTime = configIniReadWrite->value("/main/last_time").toInt();// 将值转化成整形 configIniReadWrite->setValue("/main/last_time", curTime.toTime_t()); delete configIniReadWrite; int minDiff = (curTime.toTime_t()-lastTime) / 60 + 1; return minDiff; } void Vsbak::on_checkBox_clicked() { if(ui->checkBox->isChecked()){ ui->checkBox_2->setEnabled(true); ui->checkBox_3->setEnabled(true); } else{ ui->checkBox_2->setEnabled(false); ui->checkBox_3->setEnabled(false); } } /* * 3 个 String类型 * targz:time + full.tar.gz * cmd_find:find ./ -type f | grep -v \'Permission denied\' > TEPLIST * cmd_tar *目录列表 * * * */ void Vsbak::on_pushButton_clicked(){ // The QDateTime class provides date and time functions. // 调用QDatetime里面的一个函数,赋给另一个QDatetime的类型 QDateTime current_date_time = QDateTime::currentDateTime(); // 初始化三个String类型 QString targz, cmd_find, cmd_tar; //RadioButton presents an option button that can be toggled on (checked) or off (unchecked). //Radio buttons are typically used to select one option from a set of options. //Use isChecked() to see if a particular button is selected. if(ui->radioButton->isChecked()){ // 如果radiobutton 被选择了,那么就进行备份,如果没有就只输出时间 // Linux find命令用来在指定目录下查找文件。 // 将目前目录其其下子目录中所有一般文件列出 # find . -type f // Linux grep 命令用于查找文件里符合条件的字符串。 // -v 或 --revert-match : 显示不包含匹配文本的所有行。 // 反向查找。前面各个例子是查找并打印出符合条件的行,通过"-v"参数可以打印出不符合条件行的内容。 // ./ 表示当前目录的全路径 当前目录的全路径 没有这个 \'Permission denied\'???? //linux的命令,查找文件然后设置权限 // 这个是不管修改不修改,全部列出来 cmd_find = "find ./ -type f | grep -v \'Permission denied\' > TEPLIST";// 这个功能是什么呢 targz = current_date_time.toString("yyyy-MM-dd_hh.mm.ss") + ".full.tar.gz"; }else{ // 会替换掉前面的百分之1,替换规则是从小到大 //get_min是一个函数,看它具体怎么实现的,应该是循环遍历了current_date_time,找到最小???? int minDiff = get_min(current_date_time); // 获得是最小的查值 // 完成命令,把距离最新一次全部修改的文件单独列出来 cmd_find = QString("find ./ -mmin -%1 -type f | grep -v \'Permission denied\' > TEPLIST").arg(minDiff); targz = current_date_time.toString("yyyy-MM-dd_hh.mm.ss") + ".inc.tar.gz"; } // exclude from 是一个配置目录 // tar命令 //-v或--verbose 显示指令执行过程 // --totals 备份文件建立后,列出文件大小 //cmd_tar这是压缩tar的linux命令,将exclude里面的文件全部列出来,进行压缩 cmd_tar = QString("tar --verbose --totals --exclude-vcs %1 --files-from=TEPLIST -czf %2/%3").arg(exclude_from).arg(dir_dest).arg(targz);//?5 // 向调试器输出命令的执行结果,方便调试排错 qDebug()<< cmd_find << endl << cmd_tar<< endl; // 下面整个过程就是执行这个命令 QStringList cmd_pipe;// 初始化了一个String目录 cmd_pipe << "-c" << cmd_find; // 说明这个cmd-pipe已经变成了一个linux的cmd命令了 cmd->start("/bin/bash",cmd_pipe); // 开始一个程序 cmd->waitForFinished(); cmd->close(); cmd->start(cmd_tar);// cmd_tar 也变成了一个程序 cmd->waitForFinished(); cmd->close(); cmd->start("rm -f TEPLIST");// 强制删除teplist, teplist 就是临时文件 cmd->waitForFinished(); /*********** Encrypting*************/ // gpg-k 增加公共钥匙 if(ui->checkBox->isChecked()){ QString cmd_enc; QString cmd_isKey = "gpg -k " + gpg_key; cmd->start(cmd_isKey); cmd->waitForFinished(); QString out = QString::fromLocal8Bit(cmd->readAllStandardOutput());// 这个输出就不是很理解为什么 if(out.isEmpty()) // -o, --output FILE write output to FILE // c 说是使用对称加密,看起来很奇怪 cmd_enc = QString("gpg -c -o %1/%2.gpg %1/%2").arg(dir_dest).arg(targz); else // e 是加密数据 , 针对 用户 id 进行加密 cmd_enc = QString("gpg -e -r %1 -o %2/%3.gpg %2/%3").arg(gpg_key).arg(dir_dest).arg(targz); cmd->start(cmd_enc); cmd->waitForFinished(); if(false == ui->checkBox_2->isChecked()){ QString cmd_rm = QString("rm %1/%2.gpg").arg(dir_dest).arg(targz); cmd->start(cmd_rm); cmd->waitForFinished(); } if(false == ui->checkBox_3->isChecked()){ QString cmd_rm = QString("rm %1/%2").arg(dir_dest).arg(targz); cmd->start(cmd_rm); cmd->waitForFinished(); } /* * /home/hu/桌面/vsbak/backup/2019-11-13_19.38.57.full.tar.gz * */ // ui->comboBox->addItem(targz); init_comboBox(); } } void Vsbak::on_pushButton_2_clicked(){ QString targz = ui->comboBox->currentText(); if (targz.endsWith(".tar.gz.gpg")){ targz = targz.remove(".gpg"); QString cmd_enc; QString cmd_isKey = "gpg -k " + gpg_key; cmd->start(cmd_isKey); cmd->waitForFinished(); QString out = QString::fromLocal8Bit(cmd->readAllStandardOutput()); if(out.isEmpty()) cmd_enc = QString("gpg -d -o %1/%2 %1/%2.gpg").arg(dir_dest).arg(targz); else cmd_enc = QString("gpg -d -r %1 -o %2/%3 %2/%3.gpg").arg(gpg_key).arg(dir_dest).arg(targz); cmd->start(cmd_enc); cmd->waitForFinished(); } QString cmd_str = QString("tar -xvf %1/%2").arg(dir_dest).arg(targz); qDebug() << cmd_str; cmd->start(cmd_str); cmd->waitForFinished(); } ``` 上面是cpp文件 下面是 # h文件 #ifndef VSBAK_H #define VSBAK_H #include <QWidget> #include<QProcess> QT_BEGIN_NAMESPACE namespace Ui { class Vsbak; } QT_END_NAMESPACE class Vsbak : public QWidget { Q_OBJECT public: Vsbak(QWidget *parent = nullptr); ~Vsbak(); private slots: void on_readyReadStandardOutput(); void on_readyReadStandardError(); void on_toolButton_clicked(); void on_toolButton_2_clicked(); void on_pushButton_clicked(); void on_pushButton_2_clicked(); void on_checkBox_clicked(); private: Ui::Vsbak *ui; QProcess *cmd; QString dir_dest; QString dir_src; QString gpg_key; QString exclude_from; void init_comboBox(); int get_min(QDateTime curTime);// 获得整形 }; #endif // VSBAK_H 我运行之后出来的qt界面,原本是可以下拉选择的,但是都没有反映,这是为啥
在qt的mysql数据库中如何调用数据到图表
请问如何在qt的sqlite数据库中如何调用数据到图表,例如调用priceIn和priceOut作为数据来作为坐标数据 ``` QSqlDatabase dbCommodity = QSqlDatabase::addDatabase("QSQLITE"); dbCommodity.setDatabaseName("../commodity.db");//建立数据库 if ( !dbCommodity.open()) { QMessageBox::warning(this, "error", "cannot open"); } QSqlQuery queryCommodity(dbCommodity); queryCommodity.exec("create table wareHouse("workOrg QString,currentStore int,priceIn double,priceOut double);"); void getLineSeries(QLineSeries* series)//调用数据,这里该怎么写? { qreal y1, y2; y1 =?; y2 =?; series->append(y1, y2) } //绘制折线图 QT_CHARTS_NAMESPACE::QChart * createLineChart(QLineSeries *series) { QChart *chart = new QChart(); chart->setTitle("测试line图"); series->setName("测试曲线"); getLineSeries(series);//getLineSeries函数调用 QPen pen; pen.setStyle(Qt::DotLine); pen.setWidth(2); pen.setColor(Qt::red); series->setPen(pen); chart->addSeries(series); QValueAxis *axisX = new QValueAxis(); axisX->setRange(0, 10); axisX->setLabelFormat("%.1f"); axisX->setTitleText("测试x坐标"); QValueAxis *axisY = new QValueAxis(); axisY->setRange(0, 100); axisY->setLabelFormat("%.2f"); axisY->setTitleText("测试y坐标"); chart->setAxisX(axisX, series); chart->setAxisY(axisY, series); return chart; } ```
QT中导入第三方库并使用,编译时给出LNK2019:无法解析的外部命令。
QT项目中导入libzplay这个第三方库用于音频处理,但是导入后使用时发生错误,显示 ``` mainwindow.obj:-1: error: LNK2019: 无法解析的外部符号 __imp_CreateZPlay,该符号在函数 "public: __cdecl MainWindow::MainWindow(class QWidget *)" (??0MainWindow@@QEAA@PEAVQWidget@@@Z) 中被引用 ``` 尝试过重构项目并且重新QMake但是始终会产生这个问题,真的是无力了,希望有大佬能够帮下忙 下面是项目文件和我使用时的代码: ``` QT += core gui widgets TARGET = test_import_dll TEMPLATE = app DEFINES += QT_DEPRECATED_WARNINGS # You can also make your code fail to compile if you use deprecated APIs. # In order to do so, uncomment the following line. # You can also select to disable deprecated APIs only up to a certain version of Qt. #DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0 CONFIG += c++11 SOURCES += \ main.cpp \ mainwindow.cpp HEADERS += \ mainwindow.h FORMS += \ mainwindow.ui # Default rules for deployment. qnx: target.path = /tmp/$${TARGET}/bin else: unix:!android: target.path = /opt/$${TARGET}/bin !isEmpty(target.path): INSTALLS += target unix:!macx|win32: LIBS += -L$$PWD/../../DB_project/libzplay-2.02-sdk/C++/ -llibzplay INCLUDEPATH += $$PWD/../../DB_project/libzplay-2.02-sdk/C++ DEPENDPATH += $$PWD/../../DB_project/libzplay-2.02-sdk/C++ win32:!win32-g++: PRE_TARGETDEPS += $$PWD/../../DB_project/libzplay-2.02-sdk/C++/libzplay.lib else:unix:!macx|win32-g++: PRE_TARGETDEPS += $$PWD/../../DB_project/libzplay-2.02-sdk/C++/libzplay.a ``` 建了个mainwindow想在里面测试下结果使用不了: ``` #include "mainwindow.h" #include "ui_mainwindow.h" #include<libzplay.h> using namespace libZPlay; MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ZPlay* p= CreateZPlay(); ui->setupUi(this); } MainWindow::~MainWindow() { delete ui; } ```
QT 简单QNetwork历程无法使用
新手求教,历程无法使用,在debug的时候在replyfinished函数开始处设置断点,一直没有触发 这是pro文件: QT += core gui network QT += core gui greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = weatherget TEMPLATE = app SOURCES += main.cpp\ mainwindow.cpp HEADERS += mainwindow.h FORMS += mainwindow.ui 这是头文件: #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QtNetwork/QNetworkAccessManager> #include <QtNetwork/QNetworkReply> #include <QtNetwork/QNetworkRequest> namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private: void replyFinished(QNetworkReply*); private: Ui::MainWindow *ui; QNetworkAccessManager *manager; }; #endif // MAINWINDOW_H 这是源文件: #include "mainwindow.h" #include "ui_mainwindow.h" #include <QTextCodec> MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); QUrl url(QString("http://www.weather.com.cn/adat/sk/101010100.html")); manager = new QNetworkAccessManager(this); QNetworkRequest request; request.setHeader(QNetworkRequest::ContentTypeHeader,"application/json"); request.setUrl(url); manager->get(request); connect(manager,SIGNAL(finished(QNetworkReply*)),this,SLOT(replyFinished(QNetworkReply*))); } MainWindow::~MainWindow() { delete ui; } void MainWindow::replyFinished(QNetworkReply *reply) { QTextCodec *codec = QTextCodec::codecForName("utf8"); QString all=codec->toUnicode((reply->readAll())); ui->textBrowser->setText(all); reply->deleteLater(); }
怎么在qt4中使用python?
#include <Python.h> #include <iostream> using namespace std; #define __cplusplus int main() { Py_Initialize(); return 0; } 在qt4中就写了这点的代码都编译不过,大神来看看什么问题 E:\qtClient\python\main.cpp:8: 错误:undefined reference to `_imp__Py_Initialize'
QT中编译时出现的undefined reference to 的问题
我在用QT creator想写一个串口通信程序时,跟很多人一样也是 ```D:\documents\HelloSerialPort\mainwindow.cpp:20: error: undefined reference to SPComm::isOpen() const``` ```D:\documents\HelloSerialPort\debug\mainwindow.o:-1: In function `ZN10MainWindow23on_pushButton_2_clickedEv':``` ```D:\documents\HelloSerialPort\mainwindow.cpp:30: error: undefined reference to `SPComm::isOpen() const'``` 看网上说是在pro文件中添加类所在的目录,可是我怎么知道它是哪个目录呢?完全不懂啊,求教!下面是我的文件 //mainwindow.h ``` #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include "SPComm.h" namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private slots: void on_pushButton_clicked(); void on_pushButton_2_clicked(); private: Ui::MainWindow *ui; SPComm *m_spcomm; }; #endif // MAINWINDOW_H ``` spcomm.h ``` #ifndef SPCOMM_H #define SPCOMM_H #include <QObject> #include <QtSerialPort/QtSerialPort> class SPComm : public QObject { Q_OBJECT public: explicit SPComm(QObject *parent = 0); ~SPComm(); bool isOpen() const; void setPortName(const QString &name); QString portName() const; void setBaudRate(int baudRate); int baudRate() const; virtual bool open(); virtual void close(); virtual bool clear(); int readData(char *buffer, int count, int timeout = 1000); int writeData(char *data, int size); int write(char ch); protected: QString m_portName; int m_baudRate; QSerialPort *m_serialPort; signals: public slots: }; #endif // SPCOMM_H ```
Qt creator用QMultimedia做视频播放器没图像
如题,我从网上参考了相关教程自己写了一个(原码在最后),是在Deepin环境下,编译是没错的,结果运行时弹出的窗口是全黑的,视频播放不出来,但奇怪的是有声音,即使把窗口关了也还有声音。如果我换到windows环境下,把相关的库和文件都改成windows的,也是没有报错,但直接连黑窗口都弹不出来了。我用的Qt5.9.1,创建工程时用的是QWidget基类(用其他的没写出来)。在百度上找了很长时间,说是没有gstreamer0.10-ffmpeg解码器,我试过了,这个解码器根本就下载不了。截图如下: ![图片说明](https://img-ask.csdn.net/upload/201707/15/1500129864_271640.png) 关于安装这个解码器的问题,百度说直接从官网上找安装包手动下载,我把好多安装包下载完了,结果都提示不能安装:![图片说明](https://img-ask.csdn.net/upload/201707/15/1500130132_477133.png) 又有说是源的问题,我从网上找了好多源,然后挨个换,都不能安装。还有说系统要升级到最新,可是我也升级了啊,也没什么用。不想放弃,希望得到指点,如果能得到任何帮助,我将不胜感激。 原码如下: ![图片说明](https://img-ask.csdn.net/upload/201707/15/1500130526_572704.png) ![图片说明](https://img-ask.csdn.net/upload/201707/15/1500130595_767762.png) ![图片说明](https://img-ask.csdn.net/upload/201707/15/1500130636_716614.png) ![图片说明](https://img-ask.csdn.net/upload/201707/15/1500130685_741237.png) 那个player.ui我只是画了一些按钮,没有去实现,因为在播放这块儿卡住了。 这是.pro文件: #------------------------------------------------- # # Project created by QtCreator 2017-07-15T09:24:24 # #------------------------------------------------- QT += core gui\ multimedia\ multimediawidgets greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = test5 TEMPLATE = app # The following define makes your compiler emit warnings if you use # any feature of Qt which as been marked as deprecated (the exact warnings # depend on your compiler). Please consult the documentation of the # deprecated API in order to know how to port your code away from it. DEFINES += QT_DEPRECATED_WARNINGS # You can also make your code fail to compile if you use deprecated APIs. # In order to do so, uncomment the following line. # You can also select to disable deprecated APIs only up to a certain version of Qt. #DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0 SOURCES += \ main.cpp \ player.cpp HEADERS += \ player.h FORMS += \ player.ui ```这是头文件player.h: #ifndef PLAYER_H #define PLAYER_H #include <QWidget> #include <QMediaPlayer> #include <QVideoWidget> namespace Ui { class Player; } class Player : public QWidget { Q_OBJECT public: explicit Player(QWidget *parent = 0); ~Player(); private: Ui::Player *ui; QVideoWidget *videow; QMediaPlayer *player; }; #endif // PLAYER_H ```这是main.cpp: #include "player.h" #include <QApplication> int main(int argc, char *argv[]) { QApplication a(argc, argv); Player w; w.show(); return a.exec(); } ```这是player.cpp: #include "player.h" #include "ui_player.h" Player::Player(QWidget *parent) : QWidget(parent), ui(new Ui::Player) { ui->setupUi(this); videow = new QVideoWidget(); player = new QMediaPlayer(); player->setVideoOutput(videow); player->setMedia(QUrl::fromLocalFile(QStringLiteral("/home/joe/Videos/U6-1.mpg"))); videow->show(); player->play(); } Player::~Player() { delete ui; } ```
QT creater 中 imshow error问题
在ubuntu操作系统中用imshow显示一张图显示错误。出现OpenCV Error: Assertion Failed (size.width>0 && size.height>0) in cv:imshow file图片已经加入到QT创建的那个文件中了,并且如果我用图片路径的话虽然没有显示错误,但是根本没有图片显示出来。 程序这样的: #include <QCoreApplication> #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> using namespace cv; int main(int argc, char *argv[]) { // QCoreApplication a(argc, argv); namedWindow( "src", WINDOW_AUTOSIZE ); Mat src1 = imread( "lena.jpg" ); while(1) { imshow( "src", src1 ); char c = waitKey(30); if( 27==c ) return 0; } // return a.exec(); }
qt上编译opencv程序出错
编译提取棋盘格角点的的程序,但是一直显示cvFindChessboardCorners这个函数有问题,请大神指教! 错误如下: ``` ../qt_subpix1/main.cpp: In function 'int main(int, char**)': ../qt_subpix1/main.cpp:14:19: warning: deprecated conversion from string constant to 'char*' [-Wwrite-strings] char* filename="1.jpg"; ^ ../qt_subpix1/main.cpp:20:12: warning: unused variable 'c' [-Wunused-variable] char c=getchar(); ^ ../qt_subpix1/main.cpp:37:9: error: 'CV_CALIB_CB_ADAPTIVE_THRESH' was not declared in this scope CV_CALIB_CB_ADAPTIVE_THRESH|CV_CALIB_CB_FILTER_QUADS// check page 382-383. ^ ../qt_subpix1/main.cpp:37:37: error: 'CV_CALIB_CB_FILTER_QUADS' was not declared in this scope CV_CALIB_CB_ADAPTIVE_THRESH|CV_CALIB_CB_FILTER_QUADS// check page 382-383. ^ ../qt_subpix1/main.cpp:38:4: error: 'cvFindChessboardCorners' was not declared in this scope ); ^ ../qt_subpix1/main.cpp:58:4: error: 'cvDrawChessboardCorners' was not declared in this scope ); ^ ../qt_subpix1/main.cpp: At global scope: ../qt_subpix1/main.cpp:11:5: warning: unused parameter 'argc' [-Wunused-parameter] int main(int argc, char** argv) ^ ../qt_subpix1/main.cpp:11:5: warning: unused parameter 'argv' [-Wunused-parameter] make: *** [main.o] Error 1 ``` 程序源码如下: ``` /* hellochess.cpp */ #include <iostream> #include <stdlib.h> #include <cv.h> #include <cxcore.h> #include <highgui.h> #include <math.h> using namespace std; int main(int argc, char** argv) { cout << "Draw Chess OpenCV!"<<endl; char* filename="1.jpg"; IplImage* imgRGB = cvLoadImage(filename); IplImage* imgGrey = cvLoadImage(filename,CV_LOAD_IMAGE_GRAYSCALE); if (imgGrey==NULL){//image validation cout << "No valid image input"<<endl; char c=getchar(); return 1; } //-------find chessboard corners-------------- int corner_row=9;//interior number of row corners.(this can be countered by fingers.) int corner_col=11;//interior number of column corners. int corner_n=corner_row*corner_col; CvSize pattern_size=cvSize(corner_row,corner_col); CvPoint2D32f* corners=new CvPoint2D32f(corner_n); int corner_count; int found=cvFindChessboardCorners(//returning non-zero means sucess. imgGrey,// 8-bit single channel greyscale image. pattern_size,//how many INTERIOR corners in each row and column of the chessboard. corners,//a pointer to an array where the corner locations can be recorded. &corner_count,// optional, if non-NULL, its a point to an integer where the nuber of corners found can be recorded. CV_CALIB_CB_ADAPTIVE_THRESH|CV_CALIB_CB_FILTER_QUADS// check page 382-383. ); //-------------obtain subpixel accuracy on those corners----------------------- int half_win_size=3;//the window size will be 3+1+3=7 int iteration=20; double epislon=0.1; cvFindCornerSubPix( imgGrey, corners, corner_count, cvSize(half_win_size,half_win_size), cvSize(-1,-1),//no ignoring the neighbours of the center corner cvTermCriteria(CV_TERMCRIT_ITER|CV_TERMCRIT_EPS,iteration,epislon) ); //-------Draw the corner pattern------- cvDrawChessboardCorners( imgRGB, pattern_size, corners, corner_count, found ); //to summary a bit of findings. //<<&quot;found=&quot;<<found<<endl; //cout<<&quot;x=&quot;<<corners&#91;2&#93;.x; //cout<<&quot;,y=&quot;<<corners&#91;2&#93;.y<<endl; cvNamedWindow("Find and Draw ChessBoard", CV_WINDOW_AUTOSIZE ); cvShowImage( "Find and Draw ChessBoard", imgRGB ); cvWaitKey(0); cvReleaseImage(&imgGrey); cvReleaseImage(&imgRGB); cvDestroyWindow("Find and Draw ChessBoard"); return 0; } ```
基于QT的窗口切换问题
我设计多个窗口,然后切换。问题现象是点击按钮后总是每次出现两个相同窗口,而不是只有一个。窗口界面有QWidget类,也有Dialog类。代码如下: main.cpp ``` #include "widget_login.h" //#include "mainmenu.h" #include <QApplication> int main(int argc, char *argv[]) { QApplication a(argc, argv); Widget_Login w; w.move(200, 200); w.show(); return a.exec(); } ``` 登录界面widget_login.h ``` #include <QWidget> namespace Ui { class Widget_Login; } class Widget_Login : public QWidget { Q_OBJECT public: explicit Widget_Login(QWidget *parent = 0); ~Widget_Login(); private slots: void on_pushButton_clicked(); private: Ui::Widget_Login *ui; }; #endif // WIDGET_LOGIN_H ``` widget_login.cpp ``` #include "widget_login.h" #include "ui_widget_login.h" #include "dialog.h" #include "mainmenu.h" #include <iostream> #include <fstream> Widget_Login::Widget_Login(QWidget *parent) : QWidget(parent), ui(new Ui::Widget_Login) { ui->setupUi(this); connect(ui->pushButton, SIGNAL(clicked()), this, SLOT(on_pushButton_clicked())); } Widget_Login::~Widget_Login() { delete ui; } void Widget_Login::on_pushButton_clicked() { Mainmenu *menu = new Mainmenu(); this->close(); menu->show(); } ``` 主界面mainmenu.h ``` #ifndef MAINMENU_H #define MAINMENU_H #include <QWidget> #include "oper_window.h" namespace Ui { class Mainmenu; } class Mainmenu : public QWidget { Q_OBJECT public: explicit Mainmenu(QWidget *parent = 0); ~Mainmenu(); private slots: void on_pushButton_SET_clicked(); void on_pushButton_CHECK_clicked(); void on_pushButton_OPERATION_clicked(); void on_pushButton_REPLAY_clicked(); private: Ui::Mainmenu *ui; }; #endif // MAINMENU_H ``` mainmenu.cpp ``` #include "mainmenu.h" #include "ui_mainmenu.h" #include "widget_login.h" Mainmenu::Mainmenu(QWidget *parent) : QWidget(parent), ui(new Ui::Mainmenu) { ui->setupUi(this); connect(ui->pushButton_SET, SIGNAL(clicked()), this, SLOT(on_pushButton_SET_clicked())); connect(ui->pushButton_CHECK, SIGNAL(clicked()), this, SLOT(on_pushButton_CHECK_clicked())); connect(ui->pushButton_OPERATION, SIGNAL(clicked()), this, SLOT(on_pushButton_OPERATION_clicked())); connect(ui->pushButton_REPLAY, SIGNAL(clicked()), this, SLOT(on_pushButton_REPLAY_clicked())); } Mainmenu::~Mainmenu() { delete ui; } void Mainmenu::on_pushButton_SET_clicked() { Widget_Login *wi = new Widget_Login; this->close(); wi->show(); } void Mainmenu::on_pushButton_CHECK_clicked() { } void Mainmenu::on_pushButton_OPERATION_clicked() { } void Mainmenu::on_pushButton_REPLAY_clicked() { } ```
ui(new Ui::MainWindow) 提示不允许使用不完整的类型
环境是Qt5.7+VS2015,出现如下问题: MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) //Ui::MainWindow 提示不允许使用不完整的类型 { ui->setupUi(this); } Ui定义为: namespace Ui { class MainWindowClass: public Ui_MainWindowClass {}; } // namespace Ui 但看往上其他,有的是这种定义 namespace Ui { class MainWindow: public Ui_MainWindow {}; } // namespace Ui Qt初学者,谢谢各位大牛指导了
关于Qt信号槽使用的问题
``` #include "mainwindow.h" #include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); ui->OK_Button->setText(tr("OK")); ui->lineEdit->setText("Naive"); // QObject:: connect(OK_Button,SIGNAL(clicked()),lineEdit,SLOT(btn_clicked())); } void MainWindow::btn_clicked() { QString str="Hello Earth"; ui->lineEdit->setText(str); } MainWindow::~MainWindow() { delete ui; } ``` ``` #ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include<QPushButton> #include<QLineEdit> #include<QString> #include <QPushButton> namespace Ui { class MainWindow; } class MainWindow : public QMainWindow { Q_OBJECT public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); private: Ui::MainWindow *ui; QPushButton *OK_Button; QLineEdit *lineEdit; private slots: void btn_clicked(); }; #endif // MAINWINDOW_H ``` 编译运行后编译器给出QObject::connect: No such signal MainWindow::clicked() inxxxxxxxx的提示,请问该如何解决
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
使用 Docker 部署 Spring Boot 项目
Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常简单,这篇文章我们就来简单学习下。首先构建一个简单的 S...
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
redis分布式锁,面试官请随便问,我都会
文章有点长并且绕,先来个图片缓冲下! 前言 现在的业务场景越来越复杂,使用的架构也就越来越复杂,分布式、高并发已经是业务要求的常态。像腾讯系的不少服务,还有CDN优化、异地多备份等处理。 说到分布式,就必然涉及到分布式锁的概念,如何保证不同机器不同线程的分布式锁同步呢? 实现要点 互斥性,同一时刻,智能有一个客户端持有锁。 防止死锁发生,如果持有锁的客户端崩溃没有主动释放锁,也要保证锁可以正常释...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
Android 9.0 init 启动流程
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android本篇文章主要介绍Android开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:一、启动流程概述一、 启动流程概述Android启动流程跟Linux启动类似,大致分为如下五个阶段。1.开机上电,加载固化的ROM。2.加载BootLoader,拉起Android OS。3.加载Uboot,初始外设,引导Kernel启动等。...
相关热词 c# 图片上传 c# gdi 占用内存 c#中遍历字典 c#控制台模拟dos c# 斜率 最小二乘法 c#进程延迟 c# mysql完整项目 c# grid 总行数 c# web浏览器插件 c# xml 生成xsd
立即提问