学习自唐佐林老师Qt
总结:
QBuffer缓冲区类使用QDir 目录类使用QFileSystemWatcher:
文件系统变化监控类,用于监控目录,文件是否发生变化
实验1 缓冲区的用法:
#include
#include
#include
#include
#include
void write_buffer(int type, QBuffer& buffer)
{//以二进制方式打开缓冲区 只写if( buffer.open(QIODevice::WriteOnly) ){//创建辅助类对象out,并关联到bufferQDataStream out(&buffer);out <}
void read_buffer(QBuffer& buffer)
{if( buffer.open(QIODevice::ReadOnly) ){int type &#61; -1;QDataStream in(&buffer);in >> type;//根据类型读取缓冲区中数据//读出字符串数据if( type &#61;&#61; 0 ){QString dt &#61; "";QString pi &#61; "";in >> dt;in >> pi;qDebug() <> a;in >> b;qDebug() <> pi;qDebug() <}
int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);//创建一个字节数组对象QByteArray array;//创建缓冲区对象 并绑定到 字节数组对象QBuffer buffer(&array);write_buffer(2, buffer);read_buffer(buffer);return a.exec();
}
缓冲区的作用&#xff1a;
在实际工程项目里面&#xff0c;用到缓冲区必然涉及到数据的读写&#xff0c;而读写的数据&#xff0c;他的类型可能不同&#xff0c;个数也可能不同。如果不使用缓冲区&#xff0c;那么传递数据的过程会非常复杂的&#xff0c;使用缓冲区之后&#xff0c;就可以将这些不同类型&#xff0c;不同个数的参数全部写到缓冲区里面去&#xff0c;到最后 传递的只有一个缓冲区对象&#xff0c;这样就可以简化数据的传递过程。写的是一个缓冲区对象&#xff0c;读的也是一个缓冲区对象&#xff0c;传递的只有一个缓冲区对象。
实验2 &#xff1a;QDir 使用
#include
#include
#include
#include
#include
void test_dir()
{const char* PATH &#61; "C:/Users/hp/Desktop/QDir";QDir dir;//创建目录对象if( !dir.exists(PATH) ){dir.mkdir(PATH);}if( dir.exists(PATH) ){//使用目录对象操作 目标路径dir.cd(PATH);//获取当前目录下的所有文件列表QStringList list &#61; dir.entryList();for(int i&#61;0; i}
unsigned int calculate_size(QString path)
{//创建文件属性对象 并初始化QFileInfo info(path);unsigned int ret &#61; 0;if( info.isFile() )//当前路径代表的是否为文件{ret &#61; info.size();}else if( info.isDir() )//当前路径代表的是否为文件夹&#xff0c;是的话 计算该文件夹大小{QDir dir(path);QFileInfoList list &#61; dir.entryInfoList();//for(int i&#61;0; i}
int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);test_dir();qDebug() <}
实验3&#xff1a;QFileSystemWatcher 使用
Watcher.h
#ifndef _WATCHER_H_
#define _WATCHER_H_
#include
#include
class Watcher : public QObject
{Q_OBJECTQFileSystemWatcher m_watcher;
private slots:void statusChanged(const QString& path);//槽
public:explicit Watcher(QObject *parent &#61; 0);void addPath(QString path);
};
#endif // WATCHER_H
Watcher.cpp
#include "Watcher.h"
#include
Watcher::Watcher(QObject *parent) : QObject(parent)
{connect(&m_watcher, SIGNAL(fileChanged(const QString&)), this, SLOT(statusChanged(const QString&)));connect(&m_watcher, SIGNAL(directoryChanged(const QString&)), this, SLOT(statusChanged(const QString&)));
}
void Watcher::statusChanged(const QString &path)
{qDebug() <}
void Watcher::addPath(QString path)
{m_watcher.addPath(path);
}
main.cpp
#include
#include "Watcher.h"
int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);Watcher watcher;watcher.addPath("C:/Users/hp/Desktop/text.txt");watcher.addPath("C:/Users/hp/Desktop/QDir");return a.exec();
}