Thông tin tài liệu:
Trong các giáo trình C thường chỉ hướng dẫn cách xây dựng hàm với các đối cố định. Mỗi đối cần có một tham số (cùng kiểu với nó) trong lời gọi hàm. Tuy nhiên một vài hàm chuẩn của C lại không như vậy, mà linh hoạt hơn, chẳng khi dùng hàm printf hay scanf thì số tham số mà ta cung cấp cho hàm là không cố định cả về số lượng lẫn kiểu cách. Ví dụ trong câu lệnh:
Nội dung trích xuất từ tài liệu:
HÀM VỚI ĐỐI SỐ BẤT ĐỊNH TRONG C PHỤ LỤC 4 Các phép toán quan trọng trên con trỏ gồm: HÀM VỚI ĐỐI SỐ BẤT ĐỊNH TRONG C + Gán địa chỉ một vùng nhớ cho con trỏ (dùng toán tử gán, phép lấy địa chỉ, các hàm cấp phát bộ nhớ) Trong các giáo trình C thường chỉ hướng dẫn cách xây d ựng + Truy nhập vào vùng nhớ thông qua con trỏ, dùng phép toán:hàm với các đối cố định. Mỗi đối cần có một tham số (cùng ki ểuvới nó) trong lời gọi hàm. Tuy nhiên một vài hàm chuẩn của C l ại *Tên_con_trỏkhông như vậy, mà linh hoạt hơn, chẳng khi dùng hàm printf hay (Để ý ở đây có 2 vùng nhớ: vùng nhớ của biến con trỏ và vùngscanf thì số tham số mà ta cung cấp cho hàm là không cố định c ả nhớ mà địa chỉ đầu của nó chứa trong biến con trỏ)về số lượng lẫn kiểu cách. Ví dụ trong câu lệnh: + Cộng địa chỉ để con trỏ chứa địa chỉ c ủa phần tử ti ếp theo, printf(“\n Tổng = %d “ , 3+4+5) ; dùng phép toán:có 2 tham số, nhưng trong câu lệnh: ++ Tên_con_trỏ hoặc Tên_con_trỏ ++ printf(“\n Hà Nội“ ) ; Chú ý rằng các phép toán trên chỉ có thể thực hiện đối với con trỏ có kiểu.chỉ có một tham số. Như vậy cần phân biệt các khái niệm sau: 2. Danh sách không cùng kiểu - Đối số cố định được khai báo trong dòng đầu của hàm, nó có Dùng con trỏ có kiểu chỉ quản lý được một danh sách giá trịtên và kiểu cùng kiểu, ví dụ dẫy số thực, dẫy số nguyên, dẫy các cấu trúc,.... - Tham số ứng với đối số cố định gọi là tham số cố định Khi cần quản lý một danh sách các giá trị không cùng kiểu ta phải dùng con trỏ không kiểu (void) khai báo như sau: - Đối bất định được khai báo bởi ba dấu chấm: bất định c ả v ềsố lượng và kiểu void * Tên_con_trỏ ; Con trỏ void có thể chứa các địa chỉ có kiểu bất kỳ, và dùng đ ể - Tham số bất định (ứng với đối bất định) là m ột danh sách giá trỏ đến vùng nhớ chứa danh sách cần quản lý. Một chú ý quantrị với số lượng và kiểu tuỳ ý (không xác định) trọng là mỗi khi gửi vào hay lấy ra một giá trị từ vùng nhớ, thì tuỳ Trong phụ lục này sẽ trình bầy cách xây dựng các hàm với đ ối theo kiểu giá trị mà ta phải dùng phép chuyển kiểu thích hợp đốisố bất định. Công cụ chủ yếu được dùng là con trỏ và danh sách. với con trỏ. Ví dụ sau minh hoạ cách lập một danh sách gồm một số nguyên, một số thực và một chuỗi ký tự. Chúng ta cần m ột b ộ1. Biến con trỏ nhớ để chứa số nguyên, số thực và địa chỉ chuỗi và dùng các con Biến con trỏ (hay con trỏ) dùng để chứa địa chỉ của biến, trỏ void để quản lý vùng nhớ này.mảng, hàm, ... Có nhiều kiểu địa chỉ, vì vậy cũng có nhi ều ki ểu void *list , *p ; // Con trỏ list trỏ tới đầu danh sáchcon trỏ. Biến con trỏ được khai báo theo mẫu: // p dùng để duyệt qua các phần tử của danh sách Kiểu *Tên_biến_con_trỏ ; list=malloc(sizeof(int) + sizeof(float)+ sizeof(char*) ); Ví dụ: p=list; float px ; // px là con trỏ thực 561 562 *((int*)p) = 12; // Đưa số nguyên 12 vào danh sách “3f” hiểu là : tham số bất định gồm 3 giá trị float // Chuyển sang phần tử tiếp theo “fiss” hiểu là có 4 tham số bất định có kiểu lần lượt là float, ((int*)p)++ ; int, char*, char* *((float*)p) = 3.14; // Đưa số thực 3.14 vào danh sách Một khi đã biết được địa chỉ đầu danh sách, biết được số lượng // Chuyển sang phần tử tiếp theo ((float*)p)++ ; và kiểu của mỗi tham số , thì dễ dàng nhận được 563trị các tham giá 564 *((char**)p) = “HA NOI”; // Đưa địa chỉ chuỗi “HA NOI” số để sử dụng trong thân hàm. // vào danh sách Ví dụ sau đây minh hoạ cách xây dựng các hàm với tham số bất // Nhận các phần tử trong danh sách định. Hàm dùng để in các giá trị kiểu int, float và char. Hàm có m ột tham số cố định để cho biết có bao nhiêu giá trị và kiểu các giá trị p=list; // Về đầu danh sách ...