30 câu hỏi
f là con trỏ trỏ đến tệp nhị phân DATA chứa không quá 100 bản ghi (kiểu cấu trúc) liền nhau. Cho khai báo: struct T{…}; struct T x[100]; int i=0, n=0;Đoạn chương trình nào sau đây đọc toàn bộ các bản ghi trong DATA vào x:
fread(x+i++, sizeof(T), 1, f); while (!feof(f)) fread(x+i++, sizeof(T), 1, f); fclose(f);
fseek(f,0,SEEK_END); n=ftell(f)/sizeof(T); fseek(f,0,SEEK_SET); fread(x, sizeof(T), n, f); fclose(f);
1 và 2 đúng.
1 và 2 sai.
Phát biểu nào sau đây là đúng khi nói về chế độ truyền:
1- Trong chế độ nhị phân, các byte được xử lý khác với giá trị trên thiết bị ngoại vi và có sự thực hiện chuyển đổi.
2- Trong chế độ nhị phân, các kí tự được tổ chức thành từng dòng, được kết thúc bằng kí tự xuống dòng và có sự chuyển đổi.
3- Trong chế độ văn bản, các kí tự được tổ chức thành từng dòng, mỗi dòng kết thúc bằng kí tự xuống dòng, có sự chuyển đổi của một số kí tự theo yêu cầu của môi trường.
Trong chế độ nhị phân, các byte được xử lý đúng như giá trị trên thiết bị ngoại vi và không có sự thực hiện chuyển đổi nào.
1 và 2.
1 và 3.
2 và 3.
2 và 4.
Phát biểu nào sau là đúng khi nói về hàm fgets():
Hàm đọc 1 kí tự từ tệp, nếu thành công hàm cho mã đọc được. Nếu gặp cuối tệp hoặc có lỗi, hàm cho kí tự EOF.
Hàm đọc 1 dãy kí tự từ tệp để lưu vào vùng nhớ mới.
Khi dùng hàm nếu gặp kí tự xuống dòng thì kí tự mã số 10 sẽ được thêm vào cuối xâu được đọc.
Khi dùng hàm, nếu gặp kí tự xuống dòng, thì kí tự mã số 10 và 13 sẽ được thêm vào cuối xâu được đọc.
Hàm nào dưới đây chỉ dùng để ghi 1 xâu kí tự vào tệp:
putch();
puts();
fputc();
fputs();
Phát biểu đúng nhất về mẫu lệnh (f là con trỏ tệp):while ((ch=fgetc(f))!=EOF) …
Chọn 1 phần tử và kiểm tra xem có phải là EOF hay không.
Đọc các phần tử của tệp chừng nào kí tự đó chưa phải là kí tự xuống dòng.
Ghi một phần tử và kiểm tra xem có phải là EOF hay không.
Đọc các phần tử của tệp chừng nào kí tự đó chưa phải là kí tự kết thúc.
Phát biểu nào đúng khi nói về câu lệnh fflush(FILE *f) :
Hàm làm sạch vùng nhớ của tệp f, nếu thành công cho giá trị số tệp đang mở, trái lại, trả về EOF.
Hàm làm sạch giá trị vùng nhớ của tệp f, nếu thành công hàm cho giá trị EOF, trái lại, hàm trả về 0.
Hàm làm sạch vùng nhớ của tệp f, nếu thành công trả về 0, trái lại, trả về EOF.
Hàm xóa bộ nhớ đệm của bàn phím.
Hàm nào dưới đây chỉ dùng để chuyển con trỏ về vị trí đầu tệp:
fseek();
rewind();
ftell();
seek();
Dấu hiệu nào là đúng khi sử dụng hàm fread():
int fread(void *ptr, int size, FILE *f, int n);
int fread(FILE *f, void *ptr, int size, int n);
int fread(int size, void *ptr, int n, FILE *f);
int fread(void *ptr, int size, int n, FILE *f);
Dấu hiệu nào là đúng khi sử dụng hàm fputs():
int puts(const char *s, FILE *f);
int puts(const char *s);
int puts(FILE *f, const char *s);
int puts(FILE *f);
Dấu hiệu nào là đúng khi sử dụng hàm fopen() để mở một file đã tồn tại đọc theo kiểu nhị phân:
f=fopen(“du_lieu”,”r”);
f=fopen(“du_lieu”,”w”);
f=fopen(“du_lieu”,”at”);
f=fopen(“du_lieu”,”rb”);
Dấu hiệu nào là đúng khi dùng hàm fopen() để mở file đã tồn tại, thêm theo kiểu văn bản:
f=fopen(“du_lieu”,”r+t”);
f=fopen(“du_lieu”,”r+b”);
f=fopen(“du_lieu”,”a+t”);
f=fopen(“du_lieu”,”a+b”);
Hàm nào trả lại kích thước của một tệp được mở:
long filelength(int the_file);
double filelength(int the_file);
int filelength(int the_file);
Không có đáp án nào đúng.
Câu lệnh sau có ý nghĩa gì: FILE *fopen(tep1,”ab”);
Mở tệp nhị phân để ghi.
Mở tệp nhị phân đã có và ghi thêm dữ liệu nối tiếp vào tệp này.
Mở tệp nhị phân để ghi mới.
Mở tệp nhị phân để đọc.
Hàm nào có thể thay đổi kích thước của tệp đang mở:
double chsize(int handle, long size);
long chsize(int handle, long size);
int chsize(int handle, long size);
Tất cả các đáp án trên.
Trong chế độ văn bản, dấu hiệu kết thúc tệp là:
EOF.
NULL.
\n.
Ctrl_Z.
Câu lệnh sau có ý nghĩa gì: FILE *fopen(tep1,”r+”);
Mở tệp văn bản cho phép ghi.
Mở tệp văn bản cho phép đọc.
Mở tệp văn bản cho phép cả đọc cả ghi.
Mở tệp văn bản đã tồn tại để đọc.
Câu lệnh sau có ý nghĩa gì: int open(tep1, O_TRUNC);
Mở tệp nhị phân để ghi.
Xóa nội dung của tệp.
Mở tệp văn bản để đọc và ghi.
Tất cả các đáp án trên.
Có thể truy cập thành phần của cấu trúc thông qua con trỏ như (với p là con trỏ cấu trúc, a là thành phần cấu trúc):
(*p).a;
*p->a;
1 và 2 sai.
1 và 2 đúng.
Cho khai báo:struct T {int x; float y;} t, *p, a[10];Câu lệnh nào không hợp lệ:
p=&t;
p=&t.x;
p=&a[5];
p=&a;
Cho các khai báo sau:struct ngay{ int ng, th, n;} vaotruong, ratruong; typedef struct sinhvien{ char hoten; ngay ngaysinh;};Hãy chọn câu đúng nhất:
Không được phép gán: vaotruong = ratruong;
“sinhvien” là tên cấu trúc, “vaotruong”, “ratruong” là tên biến cấu trúc.
Có thể viết “vaotruong.ng”, “ratruong.th”, “sinhvien.vaotruong.n” để truy xuất đến các thành phần tương ứng.
1, 2, 3 đúng.
Trong các khởi tạo giá trị cho các cấu trúc sau, hãy chọn câu đúng:struct S1{ int ngay, thang, nam;}; S1=(2, 1, 3); struct S2{ char hoten[10]; struct S1 ngaysinh;}; S2={“Ly Ly”, {4, 5, 6}};
S1 đúng.
S2 đúng.
Cả S1, S2 đều đúng.
Cả S1, S2 đều sai.
Đối với kiểu có cấu trúc, cách gán nào sau đây là không được phép:
Gán biến cho nhau.
Gán hai phần tử mảng (kiểu cấu trúc) cho nhau.
Gán một phần tử mảng (kiểu cấu trúc) cho một biến hoặc ngược lại.
Gán hai mảng có cấu trúc có cùng số phần tử cho nhau.
Cho đoạn chương trình sau: struct { int to; float soluong;} x[10]; for (int i=0; i<10; i++) scanf(“%d%f”,&x[i].to,&x[i].soluong);Chọn câu đúng nhất trong các câu sau:
</10;>
Đoạn chương trình trên có lỗi cú pháp.
Không được phép sử dụng toán tử lấy địa chỉ đối với các thành phần “to” và “soluong”.
Lấy địa chỉ thành phần “soluong” dẫn đến chương trình hoạt động không đúng đắn.
Cả 3 ý trên đều sai.
Để tạo danh sách liên kết, theo bạn sinh viên nào dưới đây là khai báo đúng cấu trúc tự trỏ sẽ được dùng:1- Sinh viên 1:struct SV{char ht[25]; int tuoi; struct Sv *tiep;};2- Sinh viên 2:typedef struct SV node; struct SV{char ht[25]; int tuoi; node *tiep;};3- Sinh viên 3:typedef struct SV{char ht[25]; int tuoi; struct SV *tiep;} node;
1.
2.
2 và 3.
1, 2 và 3.
Để dùng danh sách liên kết, xét hai khai báo sau (cần 1KB để lưu dữ thông tin về một sinh viên):1- Khai báo 1: struct SV{ thongtin; struct SV tiep;};2- Khai báo 2: struct SV {thongtin}; struct DS{struct SV sv; struct DS* tiep;}; (Với “thongtin” là một thành phần dữ liệu của cấu trúc);Chọn câu đúng nhất trong các câu sau:
Khai báo 1 tốn nhiều bộ nhớ hơn khai báo 2.
Khai báo 2 sẽ giúp chương trình chạy nhanh hơn khi thay đổi vị trí 2 sinh viên.
Khai báo 1 sẽ giúp tiết kiệm câu lệnh hơn khi viết hàm thay đổi vị trí 2 sinh viên.
Khai báo 2 sẽ giúp chương trình chạy nhanh hơn khi duyệt danh sách.
Cho đoạn chương trình:char S[] = “Helen”;char *p = S; char c = *(p+3);Giá trị của c sẽ là:
‘H’.
‘e’.
‘l’.
‘n’.
Chọn câu đúng:
“struct” là một kiểu dữ liệu do người dùng định nghĩa bao gồm nhiều thành phần có kiểu khác nhau.
“struct” là sự kết hợp của nhiều thành phần có thể có kiểu khác nhau.
Cả 2 ý đều đúng.
Cả hai ý đều sai.
Toán tử nào sau đây sẽ truy xuất 1 thành phần của con trỏ cấu trúc:
“.”(Toán tử chấm).
“->”(Toán tử mũi tên).
Cả hai đều đúng.
Cả hai đều sai.
Xem đoạn code sau:typedef struct ST{ int d1,d2,d3;};ST v= {5, 6, 7};ST* p=&v; p.d1++;Giá trị của biến v là:
{6, 6, 7};
{5, 6, 7};
Nhóm trị khác.
Đoạn code gây lỗi. (*p).d1++;
Xem đoạn code sau:typedef struct STUDENT{ int d1, d2, d3;};STUDENT v= {2, 3, 4}; v.d1++;Giá trị trung bình của các trường trong biến v là gì:
3.0
4.0
Giá trị khác.
Có lỗi trong đoạn code.
