QIODevice (Qt中全部 I/O devices 的基类,QFile,QBuffer,QTcpSocket等)

 QIODevice是全部Qt I/O设备的基类,它提供了对支持块读写设备(例如QFile,QBuffer,QTcpSocket)的通用实现和抽象接口。QIODevice是一种抽象,不能被实例化,可是,利用其提供的通用接口能够实现设备无关的I/O特性。html

       在访问设备前,必须首先使用open()函数打开并设定正确的访问模式OpenMode(例如ReadOnly/ ReadWrite)。而后,可用write()或者putChar()写设备,或利用read(),readLine(),readAll()读设备。完事以后用close()关闭设备。QIODevice具备如下信号:编程

readyRead() -- 当data有新数据准备好时发出信号。例如,新数据经过network到达或者有数据附加到了你正在读取的文件以后;安全

bytesAvailable()-- 肯定当前可读数据的字节数,当对非同步设备例如QTcpSocket(此类设备的数据段到达的时间是随机的)编程时,常与readyRead()信号联用。网络

bytesWritten() -- 每当负载数据被写入设备时触发该信号。使用bytesToWrite()信号肯定当前等待被写入的数据量。dom

某些QIODevice类,例如QTcpSocket和QProcess,是非同步的。如write() 或者read()之类的函数老是当即返回,而此时设备可能在函数返回事件循环(event loop)期间通讯。QIODevice提供了能够强制操做当即被执行,阻塞回调线程,不用进入事件循环的函数:异步

waitForReadyRead() ------This function suspends operation in the calling thread until new data is available for reading.
waitForBytesWritten() - ---This function suspends operation in the calling thread until one payload of data has been written to the device.
waitFor....() ------------------Subclasses of QIODevice implement blocking functions for device-specific operations. For example, QProcess has a function called waitForStarted() which suspends operation in the calling thread until the process has started.
从主函数,GUI线程调用这些函数可能致使界面冻结:函数

 1 QProcess gzip;
 2  gzip.start("gzip", QStringList() << "-c");
 3  if (!gzip.waitForStarted())
 4      return false;
 5 
 6  gzip.write("uncompressed data");
 7 
 8  QByteArray compressed;
 9  while (gzip.waitForReadyRead())
10      compressed += gzip.readAll();

转自:http://m.blog.csdn.net/article/details?id=45245915oop

 

QIODevice为支持读写数据块的device提供通用的实现和抽象接口,如QFile,QBuffer,QTcpSocket。spa

QIODevice 是一个抽象类,因此不能被实例化。但一般会用到它定义的接口,这些接口提供设备依赖的I/O特性。例如Qt的XML类经过操做一个QIODevice 的 指针,可使用各类各样的设备(files,buffers等)。.net

在访问设备以前,先调用open(),并设置正确的OpenMode(例如ReadOnly或者ReadWrite)。你能够用write(),putChar()来写入设备。也能够用read(),readLine()来读设备。使用完毕后调用close().

QIODevice 区分两种类型的设备Random-access(随机读取)和Sequential(顺序读取)。

isSequential()用来判断具体的类型是啥。

当数据可读时,QIODevice发射readyRead()信号,例如新数据抵达网络,或者附加的数据追加到你正在读取的文件中。你能够调用bytesAvailable()来肯定当前可读的字节数。在QTcpSocket中(零散的数据可能随时到达),常常把readyRead()信号和bytesAvailable()一块用。

当数据已经写入设备时,QIODevice会放射bytesWriten()信号.btyesToWriten()肯定当前将要被写人的数据的字节数。

某些子类如QTcpSocket 和 QProcess 是异步的。意味着read() 和 write()老是马上返回。QIODevice提供函数容许你从这些操做中当即返回,当阻塞在调用线程而且没有进入事件循环时。QIODevice 容许子类在没有事件循环的状况,或者在一个独立的线程中使用。

waitForReadyRead()将阻塞线程直到数据到来。

waitForBytesWriten()将阻塞线程直到数据写入。

waitFor…()子类会实现相应的函数为了特殊的操做。好比QProcess有个叫waitForStarted()的函数。它将会延迟调用的线程,直到那个process已经启动。

经过子类化QIODevice,能够提供相同的接口为本身I/O设备。QIODevice的子类仅须要实现protected的readData()和writeData(),QIODevice用这些函数实现了不少方便使用的函数。例如getChar(),readLine(),write()。QIODevice能够为你提供访问控制。能够安全的假设当writeData()函数被调用时,设备已打开。

一些子类,如QFile,QTcpSocket,会使用内存缓冲区实现存储临时的数据。这将减小设备访问的次数,从而提升读写效率。它将是getChar(),putChar()这样的函数更有效率,当你在内存缓冲区中操做数据而不是和访问设备自己。

转自:http://blog.csdn.net/u011125673/article/details/50475243

相关文章
相关标签/搜索