DÒNG NHẬP/XUẤT FILE

Một phần của tài liệu Dẫn nhập - Tìm hiểu một phạm vi của các khả năng đủ để phần lớn các thao tác nhập xuất (Trang 33 - 35)

14: cin >> X;

8.11DÒNG NHẬP/XUẤT FILE

Để thực thi xử lý file trong C++, các chương trình phải include tập tin <iostream.h>

<fstream.h>. Header <fstream.h> gồm định nghĩa cho các lớp dòng ifstream cho nhập (đọc) từ một file, ofstream cho xuất (ghi) tới một file) và fstream cho nhập/xuất (đọc/ghi) tới một file. Các file được mở bằng cách tạo các đối tượng của các lớp dòng này. Cây phả hệ của các lớp này ở hình 8.2.

 Constructor của lớp ofstream: (1) ofstream();

(2) ofstream(const char* szName,int nMode=ios::out,int

nProt=filebuf::openprot);

(3) ofstream(int fd);

(4) ofstream(filedescfd,char*pch,intnLength);

Trong đó:

szName: Tên file được mở.

nMode: Một số nguyên chứa các bit mode định nghĩa là kiểu liệy kê của ios. Có thể kết hợp bằng toán tử |. Tham số này có thể một trong các giá trị sau:

Mode Ý nghĩa

ios::app Hàm di chuyển con trỏ file tới end-of-file. Khi các byte mới được ghi lên file, chúng luôn luôn nối thêm vào cuối, ngay cả vị trí được di chuyển với hàm ostream::seekp().

ios::ate Hàm di chuyển con trỏ file tới end-of-file. Khi byte mới đầu tiên được ghi lên file, chúng luôn luôn nối thêm vào cuối, nhưng khi các byte kế tiếp được ghi, chúng ghi vào vị trí hiện hành.

ios::in Mở file để đọc.Với dòng ifstream, việc mở file đương nhiên được thực hiện ở chế độ này.

được thực hiện ở chế độ này.

ios::trunc Xóa file hiện có trên đĩa và tạo file mới cùng tên. Cũng có hiểu đây là chặt cụt file cũ, làm cho kích thước của nó bằng 0, chuẩn bị ghi nội dung mới. Mode này được áp dụng nếu ios::out được chỉ định và ios::app, ios::ate, và ios::in không được chỉ định.

ios::nocreate Nếu file không tồn tại thì thao tác mở thất bại.

ios::noreplace Nếu file tồn tại thì thao tác mở thất bại.

ios::binary Mở file ở chế độ nhị phân (mặc định là ở chế độ văn bản).

nProt: Đặc tả chế độ bảo vệ file.

fd: Mã nhận diện file.

pch: Con trỏ trỏ tới vùng dành riêng chiều dài nLength. Giá trị NULL (hoặc

nLength=0) dẫn đến dòng không vùng đệm.

nLength: Chiều dài tính theo byte của vùng dành riêng (0=không vùng đệm). Dạng (1) xây dựng một đối tượng ofstream mà không mở file.

Dạng (2) xây dựng một đối tượng ofstream và mở file đã chỉ định.

Dạng (3) xây dựng một đối tượng ofstream và gắn (attach) với một file mở.

Dạng (4) xây dựng một đối tượng ofstream mà liên kết với đối tượng filebuf. Đối tượng

filebuf được gắn tới file mở và vùng dành riêng.  Constructor của lớp ifstream:

(1) ifstream();

(2) ifstream(const char* szName,int nMode=ios::in,int nProt=filebuf::openprot);

(3) ifstream(int fd); (adsbygoogle = window.adsbygoogle || []).push({});

(4) ifstream(filedescfd,char*pch,intnLength);

Dạng (1) xây dựng một đối tượng ifstream mà không mở file. Dạng (2) xây dựng một đối tượng ifstream và mở file đã chỉ định.

Dạng (3) xây dựng một đối tượng ifstream và gắn (attach) với một file mở.

Dạng (4) xây dựng một đối tượng ofstream mà liên kết với đối tượng filebuf. Đối tượng

filebuf được gắn tới file mở và vùng dành riêng.  Constructor của lớp fstream:

(1) fstream();

(2) fstream(const char* szName,int nMode,int nProt=filebuf::openprot);

(3) fstream(int fd);

(4) fstream(filedescfd,char*pch,intnLength);

Dạng (1) xây dựng một đối tượng fstream mà không mở file. Dạng (2) xây dựng một đối tượng fstream và mở file đã chỉ định.

Dạng (3) xây dựng một đối tượng fstream và gắn (attach) với một file mở.

Dạng (4) xây dựng một đối tượng ofstream mà liên kết với đối tượng filebuf. Đối tượng

filebuf được gắn tới file mở và vùng dành riêng.

 Hàm ofstream::open():

voidopen(constchar*szName,intnMode=ios::out,int nProt=filebuf::openprot);

Hàm ifstream::open():

voidopen(constchar*szName,intnMode=ios::in,int nProt=filebuf::openprot);

Hàm fstream::open():

voidopen(constchar*szName,intnMode,intnProt=filebuf::openprot);

Để đóng file chúng ta dùng hàm close(), hàm này ở các lớp ifstream, ofstream, và fstream đều có dạng:

void close();

Các hàm liên quan đến con trỏ file: Lớp istream:

Hàm seekg(): (seek get)

(1) istream& seekg(streampos pos);

(2) istream& seekg(streamoff off,ios::seek_dir dir);

Trong đó:

+ pos: Vị trí mới. streampos là tương đương typedef với long. + off: Giá trị offset mới. là tương đương typedef với long. + dir: hướng seek. Có một trong các trị sau:

ios::begin Seek từ bắt đầu của dòng.

ios::cur Seek tư øvị trí hiện hành của dòng

ios::end Seek từ cuối của dòng Hàm tellg(): (tell get) (adsbygoogle = window.adsbygoogle || []).push({});

streampos tellg();

Hàm trả về vị trí hiện hành của con trỏ file. Lớp ostream:

Hàm seekp(): (seek put)

(1) ostream& seekp(streampos pos);

(2) ostream& seekp(streamoff off,ios::seek_dir dir);

Hàm tellp(): (tell put)

streampos tellp();

Hàm trả về vị trí hiện hành của con trỏ file.

Một phần của tài liệu Dẫn nhập - Tìm hiểu một phạm vi của các khả năng đủ để phần lớn các thao tác nhập xuất (Trang 33 - 35)