Tải bản đầy đủ (.pdf) (3 trang)

Các Chủ Đề Tiến Bộ Trong C# part 5

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (136.24 KB, 3 trang )


Các chỉ thị tiền xử lí trong C#
Bên cạnh các từ khoá thường dùng, C# có 1 số lệnh tiền xử lí .những lệnh này không bao
giờ được biên dịch thành bất kì dòng lệnh nào trong mã thực thi. thay vào đó nó có ảnh
hưởng đến các khía cạnh của quy trình biên dịch. ví dụ , ta có thể dùng chỉ dẫn tiền xử lí
để ngăn trình biên dịch biên dịch một phần đoạn mã nào đó .
Chỉ thị tiền xử lí được phân biệt bằ
ng cách bắt đầu với dấu # .
#define và #undef
#define được dùng ví dụ như :
#define DEBUG
Cho trình biên dịch biết biểu tượng với tên được đặt ( DEBUG) tồn tại. nó hơi giống như
khai báo biến nhưng nó không có giá trị - mà chỉ tồn tại.
Trái ngược với #define là #undef : bỏ định nghĩa biểu tượng : #undef DEBUG
Ta cần đặt các chỉ thị #define và #undef vào đầu tập tin nguồn trước bất kì khai báo đối
tượng được biên dịch.
lưu ý : các chỉ thị tiền xử lí không có dấu ' ; ' ở cuối câu lệnh thường thì các lệnh chỉ trên
1 dòng . nếu nó thấy 1 chỉ thị tiền xử lí, nó xem lệnh kết tiếp sẽ nằm ở dòng kế tiếp.
#if,#elif,#else,#endif
các chỉ
thị này thông báo cho trình biên dịch biết liệu có biên dịch đoạn mã hay không, ví
dụ :
int DoSomeWork(double x)
{
// do something
#if DEBUG
Console.WriteLine("x is " + x);
#endif
}

Dòng lệnh Console.Writeline chỉ được thực hiện khi DEBUG được định nghĩa.( bằng chỉ


thị #define). khi thấy #if nó kiểm tra xem biểu tượng có tồn tại hay không nếu có thì biên
dịch đoạn mã bên trong ngược lại bỏ qua đoạn mã bên trong giữa #if và #endif. ta dùng
cách này khi muốn vá lỗi, mà lỗi liên quan đến đoạn mã trong #if ,khi muốn đoạn mã này
chạy ta định nghĩa DEBUG, khi muốn nó không chạy ta #undef DEBUG,kích cỡ cũa tập
tin thực thi sẽ nhỏ
hơn.
Các chỉ thị #elif (= else if ) và # else được dùng trong khối #if .và có thể lồng khối #if

#define ENTERPRISE
#define W2K

// further on in the file

#if ENTERPRISE
// do something
#if W2K
// some code that is only relevant to enterprise
// edition running on W2K
#endif
#elif PROFESSIONAL
// do something else
#else
// code for the leaner version
#endif

#if và #elif cũng hổ trợ 1 số tác tử luận lý , dùng !,==,!=,||. 1 biểu tượng là true nếu nó tồn
tại và ngược lại là false. ví dụ :
#if W2K && (ENTERPRISE==false) // nếu W2K đưọc định nghĩa còn ENTERPRISE
thì không
#warning và #error

Nếu trình biên dịch thấy #warning nó sẽ trình bày chuỗi xuất iện phía sau nó đến người
dùng,sau đó biên dịch tiếp. nếu thấy chỉ thi #error ,nó sẽ trình bày chuỗi con đến người
dùng nếu đó là 1 thông báo lỗi biên dịch , sau đó ngừng biên dịch
#if DEBUG && RELEASE
#error "You've defined DEBUG and RELEASE simultaneously! "
#endif

#warning "Don't forget to remove this line before the boss tests the code! "
Console.WriteLine("*I hate this job*");

#region và #endregion
Các chỉ thị #region và #endregion đưọc dùng để đánh dấu khối mã được xem như là khối
đơn với tên được đặt như :
#region Member Field Declarations
int x;
double d;
Currency balance;
#endregion
chỉ thị này không có ảnh hưởng nào đến trình biên dịch nhưng nó hữu ích cho 1 số trình
biên tập bao gồm cả trình biên tập của VS.NET. trình biên tập có thể dùng chỉ thị naỳ để
gói gọn mã của ta trên màn hình.
# line
chỉ thị #line có thể được dùng thay cho tên tập tin và thông tin số dòng mà xuất bởi trình
biên dịch trong các thông báo cảnh báo hay lỗi .nó thường dùng khi bạn viết mã kết hợp
với 1 số gói khác mà sau đó sẽ thay đoạn mã bạn gõ vào trước khi biên d
ịch ,trình biên
dịch sẽ thông báo số dòng và tên tập tin không phù hợp với số dòng trong tập tin mà bạn
đang chỉnh sửa .chỉ thị #line có thể được dùng để lưu sự phù hợp. ta cũng có thể dùng cú
pháp #line default để lưu dòng thành số dòng mặc định :
#line 164 "Core.cs" // we happen to know this is line 164 in the file

// Core.cs, before the intermediate
// package mangles it.

// later on

#line default // restores default line numbering





 

×