QIODevice类是对所有读和写一段字节块的一个抽象。Qt包含了下面的一些子类:
QFile |
访问本地文件系统中的文件或嵌入的资源。 |
QTemporaryFile |
创建或访问本地文件系统中的临时文件。 |
QBuffer |
从一个QByteArrary中读数据或将数据写入到一个QByteArray中。 |
QProcess |
运行外部程序并处理进程间的通信。 |
QTcpSocket |
使用TCP协议传输一个数据流。 |
QUdpSocket |
通过网络发送或接收UDP数据流。 |
其中,QProcess,QTcpSocket,QUdpSocket是顺序文件,只能顺序访问,而QFile,QTemporaryFile, QBuffer是随机访问文件,可随机访问,可使用QIODevice::seek()来重定位文件指针。
另外,Qt也提供了两个更高级的流处理类,可用于向任何QIODevice设备中读或写数据。其中QDataStream用于读写二进制数据,而QTextStream用于读写文本数据。
QTextStream负责处理Unicode与系统本地编码格式或任何其他编码格式的转换。QTextStream使用16-位的QChar类型作为数据的基本单元。另外,QTextStream也支持c++的基本数据类型。
使用例子如下所示:
QFile file("sf-book.txt");
if (!file.open(QIODevice::WriteOnly)) {
cerr << "Cannot open file for writing: "
<< qPrintable(file.errorString()) << endl;
return;
}
QTextStream out(&file);
out << "Thomas M. Disch: " << 334 << endl;
注意:写数据可能要容易些,但读数据就要复杂些,如
out<< "Norway" << "Sweden";如果使用in>> str1 >> str2;读的话,结果却是str1=”NorwaySweden”,而str2为空。因此,读数据必须使用专门的程序解析,QTextStream可以逐字符(QChar)地读取。
可以设置字符编码,如:
stream.setCodec("UTF-8");
QTextStream也支持一些流操作标志,如:
out<< showbase << uppercasedigits << hex <<12345678;
或
out.setNumberFlags(QTextStream::ShowBase
|QTextStream::UppercaseDigits);
out.setIntegerBase(16);
out<< 12345678;
读写二进制文件
QDataStream用于读写原始数据文件。在读写文件中,主要涉及两个问题:1.数据类型大小。2.Qt版本。
数据类型问题:确保读和写使用相同的数据类型。比如,对于整数,最好使用qint8,qint16和qint32,qint64,它们对于不同平台,数据类型大小都是一样的。避免使用int, short , long等数据类型,它们在不同平台上大小可能不同。
Qt版本:不同的Qt版本使用的二进制数据的编码可以不同。
QDataStream可序列化所有基本的C++类型和大部分Qt类型,如QColor,QList, QString等。要使得QDataStram能序列化一个自定义的类型,必须提供相应的<<和>>操作符重载函数。代码例子如下:
struct ColorText
{
QString text;
QColor color;
};
QDataStream &operator<<( QDataStream &stream, const ColorText &data )
{
stream << data.text << data.color;
return stream;
}
QDataStream &operator>>( QDataStream &stream, ColorText &data )
{
stream >> data.text;
stream >> data.color;
return stream;
}
QList<ColorText> list;
ColorText data;
data.text = "Red";
data.color = Qt::red;
list << data;
...
QFile file( "test.dat" );
if( !file.open( QIODevice::WriteOnly ) )
return;
QDataStream stream( &file );
stream.setVersion( QDataStream::Qt_4_2 );
stream << list;
file.close();
QList<ColorText> list;
QFile file( "test.dat" );
if( !file.open( QIODevice::ReadOnly ) )
return;
QDataStream stream( &file );
stream.setVersion( QDataStream::Qt_4_2 );
stream >> list;
file.close();
foreach( ColorText data, list )
qDebug() << data.text << "("
<< data.color.red() << ","
<< data.color.green() << ","
<< data.color.blue() << ")";
访问目录
QDir类可用于浏览路径中的目录和文件。QDir提供了一些静态方法,可以很容易地浏览文件系统。如:
-
QDir::current()返回应用程序当前所在的工作目录。
-
QDir::home()返回用户的主目录。
-
QDir::root()返回根用户目录。
-
QDir::temp()返回临时文件目录。
-
QDir::drives()返回一个包含了QFileInfo对象的列表。
QFileInfo类提供了访问文件和目录信息的方法,如:
-
isDir(),isFile(), isSymLink():判断文件是否属于目录,一般文件或符号链接文件。
-
dir(),absoluteDir():返回相对目录或绝对目录。
-
exists();判断文件对象是否存在。
-
isHidden(),isReadable, isWritable()和isExecutable():判断一个文件是否隐藏、可读、可写或可执行。
-
fileName():返回文件名。
-
filePath():返回文件名(包含路径)
-
absoluteFilePath():返回包含绝对路径的文件名。
-
completeBaseName(),completeSuffix():返回文件名和文件名后缀。
例如如下:
foreach( QFileInfo drive, QDir::drives() )
{
qDebug() << "Drive: " << drive.absolutePath();
QDir dir = drive.dir();
dir.setFilter( QDir::Dirs );
foreach( QFileInfo rootDirs, dir.entryInfoList() )
qDebug() << "" << rootDirs.fileName();
}