Hey please don\'t mind if I am asking trivial question, but, please can somebody help me with this..
It's useful when you do a lot of random read/write operations. There is even an option for SQLite3 that replaces seek()
+ read()
and seek()
+ write()
with pread()/pwrite()
.
The advantage: seek()
+ read()
and seek()
+ write()
both are the pairs of system calls while pread()
and pwrite()
are single system calls. It's usually an universal truth that the less system calls program issues the more efficient it is.
There are two parts:
Difference between pread
/pwrite
and read
/write
:
They are both at the same level, namely system calls. There are two differences:
Difference between read
/pread
/write
/pwrite
and fread
/fwrite
:
The "f" variants are standard runtime wrappers of the former (using the basic variants). They support in-process buffering. That can significantly improve performance for simple code, but it makes use of other features of the system-call level impractical.
Only use the "p" variants if you have good use for reading at random offsets (avoiding seeks and allowing concurrent access via one file handle), which often the case with some kind of database files (record-oriented with records at known offsets) and rarely in other applications.
Current file position doesn't change after a call to pread
/pwrite
.
Also because you don't need to call lseek
to change the current file position pread
/pwrite
avoid potential race conditions when multiple threads are involved.