IV. TỔ CHỨC CHƯƠNG TRÌNH 1 Các loại biến và phạm
2. Chỉ thị macro #define
#define tên_macro xaukitu
Trước khi dịch bộ tiền xử lý sẽ tìm trong chương trình và thay thế bất kỳ vị trí xuất hiện nào của tên_macro bởi xâu kí tự. Ta thường sử dụng macro để định nghĩa các hằng hoặc thay cụm từ này bằng cụm từ khác dễ nhớ hơn, ví dụ:
#define then // thay then bằng dấu cách
#define begin { // thay begin bằng dấu {
#define end } // thay end bằng dấu }
#define MAX 100 // thay MAX bằng 100
#define TRUE 1 // thay TRUE bằng 1
từ đó trong chương trình ta có thể viết những đoạn lệnh như: if (i < MAX) then
begin
Ok = TRUE; cout << i ; end
trước khi dịch bộ tiền xử lý sẽ chuyển đoạn chương trình trên thành if (i < 100)
{
Ok = 1; cout << i ; }
theo đúng cú pháp của C++ và rồi mới tiến hành dịch.
Ngoài việc chỉ thị #define cho phép thay tên_macro bởi một xâu kí tự bất kỳ, nó còn cũng được phép viết dưới dạng có đối. Ví dụ, để tìm số lớn nhất của 2 số, thay vì ta phải viết nhiều hàm max (mỗi hàm ứng với một kiểu số khác nhau), bây giờ ta chỉ cần thay chúng bởi một macro có đối đơn giản như sau:
#define max(A,B) ((A) > (B) ? (A): (B))
khi đó trong chương trình nếu có dòng x = max(a, b) thì nó sẽ được thay bởi: x = ((a) > (b) ? (a): (b))
Chú ý:
• Tên macro phải được viết liền với dấu ngoặc của danh sách đối. Ví dụ không viết max (A,B).
• #define bp(x) (x*x) viết sai vì bp(5) đúng nhưng bp(a+b) sẽ thành (a+b*a+b) (tức a+b+ab).
• Cũng tương tự viết #define max(A,B) (A > B ? A: B) là sai (?) vì vậy luôn luôn bao các đối bởi dấu ngoặc.
• #define bp(x) ((x)*(x)) viết đúng nhưng nếu giả sử lập trình viên muốn tính bình phương của 2 bằng đoạn lệnh sau:
int i = 1;
cout << bp(++i); // 6
thì kết quả in ra sẽ là 6 thay vì kết quả đúng là 4. Lí do là ở chỗ chương trình dịch sẽ thay bp(++i) bởi ((++i)*(++i)), và với i = 1 chương trình sẽ thực hiện như 2*3 = 6. Do vậy cần cẩn thận khi sử dụng các phép toán tự tăng giảm trong các macro có đối. Nói chung, nên hạn chế việc sử dụng các macro phức tạp, vì nó có thể gây nên những
hiệu ứng phụ khó kiểm soát.