Hàm int vfprintf(FILE *stream, const char *format, va_list arg) trong Thư viện C chuẩn gửi output đã được định dạng tới một stream bởi sử dụng một danh sách tham số.
Khai báo hàm vfprintf() trong C
Dưới đây là phần khai báo cho hàm vfprintf() trong C:
int vfprintf(FILE *stream, const char *format, va_list arg)
Tham số
stream − Đây là con trỏ tới một đối tượng FILE mà nhận diện Stream.
format − Đây là chuỗi chứa text để được ghi tới Stream. Nó có thể tùy ý chứa các thẻ định dạng có thể được nhúng mà được thay thế bởi các giá trị được xác định trong các tham số bổ sung tiếp theo và được định dạng theo yêu cầu. Nguyên mẫu các thẻ định dạng là %[flags][width][.precision][length]specifier, được giải thích như dưới đây:
specifier | Kết quả |
---|---|
c | Ký tự |
d hoặc i | Số nguyên hệ thập phân có dấu |
e | Ký hiệu khoa học (mantissa/exponent) sử dụng ký tự e |
E | Ký hiệu khoa học (mantissa/exponent) sử dụng ký tự E |
f | Số thực dấu chấm động hệ thập phân |
g | Sử dụng rút gọn của %e hoặc %f |
G | Sử dụng rút gọn của %E hoặc %f |
o | Số bát phân có dấu |
s | Chuỗi ký tự |
u | Số nguyên hệ thập phân không dấu |
x | Số nguyên hệ thập lục phân không dấu |
X | Số nguyên hệ thập lục phân không dấu (các chữ cái hoa) |
p | Địa chỉ con trỏ |
n | Không in cái gì |
% | Ký tự |
flags | Miêu tả |
---|---|
– | Căn chỉnh trái vào bên trong độ rộng trường đã cho. Căn chỉnh phải là mặc định |
+ | Ép buộc đặt trước kết quả một dấu cộng hoặc trừ (+ hoặc -) ngay cả với các số dương. Theo mặc định, chỉ có các số âm được đặt trước bởi một dấu – |
(space) | Nếu không có ký hiệu nào được ghi, thì một khoảng trống sẽ được chèn trước giá trị |
# | Được sử dụng với các specifier là o, x hoặc X. Giá trị được đặt trước với 0, 0x hoặc 0X tương ứng cho các giá trị khác 0. Sử dụng với e, E và f, nó ép buộc output đã được ghi để thu nhận một con trỏ thập phân ngay cả nếu không có chữ số nào theo sau. Theo mặc định, nếu không có chữ số nào theo sau thì không có con trỏ thập phân được ghi. Sử dụng với g hoặc G, kết quả là giống với e hoặc E nhưng các số 0 ở cuối không bị gỡ bỏ |
0 | Đệm vào bên trái (left-pad) của số với các số 0 thay vì bởi các khoảng trống |
width | Miêu tả |
---|---|
(number) | Số ký tự tối thiểu để được in. Nếu giá trị để được in là ngắn hơn số này, thì kết quả được đệm thêm với các khoảng trống. Giá trị không bị cắt ngay cả khi kết quả là quá lớn |
* | Độ rộng không được xác định trong chuỗi định dạng format, nhưng như một tham số giá trị nguyên bổ sung đặt trước tham số đó mà phải được định dạng |
.precision | Miêu tả |
---|---|
.number | Với các Integer Specifier (d, i, o, u, x, X) − thì Precision xác định số chữ số nhỏ nhất được ghi. Nếu giá trị được ghi là ngắn hơn số này thì kết quả được đệm thêm với các 0 vào đầu. Giá trị không bị cắt ngay cả nếu kết quả là dài hơn. Một precision là 0 nghĩa là không có ký tự nào được ghi cho giá trị 0. Với e, E và f specifier: đây là số chữ số để được in sau điểm thập phân. Với g và G specifier: đây là số chữ số có nghĩa tối đa để được in. Với s specifier: đây là số ký tự tối thiểu để được in. Theo mặc định, tất cả ký tự được in tới khi bắt gặp ký tự null cuối cùng. Với kiểu c: nó không có ảnh hưởng. Khi không có precision nào được xác định, thì mặc định là 1. Nếu period được xác định mà không kèm với một giá trị precision rõ ràng, thì 0 được giả sử |
.* | Precision không được xác định trong chuỗi định dạng format, nhưng như một tham số giá trị nguyên bổ sung đặt trước tham số đó mà phải được định dạng |
length | Miêu tả |
---|---|
h | Tham số được thông dịch như một short int hoặc unsigned short int (chỉ được áp dụng cho integer specifiers: i, d, o, u, x và X) |
l | Tham số được thông dịch như một long int hoặc unsigned long int cho integer specifier (i, d, o, u, x và X), và như một wide char hoặc wide char string cho các specifier là c và s |
L | Tham số được thông dịch như một long double (chỉ được áp dụng cho các floating point specifier: e, E, f, g và G) |
Các tham số bổ sung − Phụ thuộc vào chuỗi định dạng format, hàm này có thể có một dãy tham số bổ sung, mỗi tham số chứa một giá trị để được chèn thay cho mỗi %-tag được xác định trong tham số format, nếu có. Số tham số này nên cùng số lượng với số %-tags mà mong chờ một giá trị.
Trả về giá trị
Nếu thành công, tổng số ký tự đã được ghi sẽ được trả về, nếu không sẽ trả về một số âm.
Ví dụ
Chương trình C sau minh họa cách sử dụng của hàm vfprintf() trong C:
#include <stdio.h> #include <stdarg.h> void WriteFrmtd(FILE *stream, char *format, ...) { va_list args; va_start(args, format); vfprintf(stream, format, args); va_end(args); } int main () { FILE *fp; fp = fopen("baitapc.txt","w"); WriteFrmtd(fp, "Diem %d cho chat luong \n", 10); fclose(fp); return(0); }
Biên dịch và chạy chương trình trên sẽ mở baitapc.txt để ghi vào thư mục hiện tại và sẽ ghi nội dung sau:
Bây giờ theo dõi nội dung file trên bởi sử dụng chương trình C sau:
#include <stdio.h> int main () { FILE *fp; int c; fp = fopen("baitapc.txt","r"); while(1) { c = fgetc(fp); if( feof(fp) ) { break; } printf("%c", c); } fclose(fp); return(0); }
Biên dịch và chạy chương trình C trên sẽ cho kết quả sau:
19 Th3 2021
18 Th3 2021
18 Th3 2021
19 Th3 2021
18 Th3 2021
19 Th3 2021