Bài giảng Thực hành chương trình dịch: Bài 4 - Phạm Đăng Hải
lượt xem 3
download
Bài giảng "Thực hành chương trình dịch: Bài 4 - Phân tích ngữ nghĩa" được thực hiện nhằm giúp các bạn sinh viên nắm được vị trí của bộ phân tích ngữ nghĩa; nhiệm vụ của bộ phân tích ngữ nghĩa; bảng ký hiệu trong KPL; phân tích ngữ nghĩa;... Mời các bạn cùng tham khảo bài giảng!
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Thực hành chương trình dịch: Bài 4 - Phạm Đăng Hải
- Thực hành CHƯƠNG TRÌNH DỊCH Bài 4: Phân tích ngữ nghĩa Phạm Đăng Hải haipd@soict.hut.edu.vn
- Ví dụ 1 Cho văn phạm G = ( , , P, S) P: { | | | « Bò »| « Cỏ »| « Vàng »| « Non » « gặm» } 09/20/23 2
- Ví dụ 1 L(G) = « Bò vàng gặm cỏ non » Các câu đều đúng ngữ pháp, « Bò vàng gặm cỏ vàng » nhưng không « Bò non gặm cỏ non » phải câu nào « Bò vàng gặm bò non » cũng đúng ngữ « Cỏ non gặm bò vàng » nghĩa (có ý nghĩa) ….. 09/20/23 3
- Ví dụ 2 := Program Toto; := Const N = 0; N:= Begin N:= N:= N :=10; N:= End. N:= N:=10 Hoàn toàn đúng cú pháp của KPL Sử dụng sai ý nghĩa ban đầu (Hằng số) 09/20/23 4
- Nhận xét • Không phải mọi câu văn (NNLT: câu lệnh) đúng ngữ pháp (NNLT: cú pháp) đều có giá trị sử dụng (NNLT: thực hiện được) • Bộ phân tích ngữ nghĩa nhằm mục đích kiểm tra tính đúng đắn về mặt ngữ nghĩa của câu văn (NNLT: câu lệnh) 09/20/23 5
- Vị trí của bộ phân tích ngữ nghĩa • Phân tích cú pháp Phân tích – Kiểm tra cấu trúc ngữ pháp hợp lệ từ vựng của chương trình • Những yêu cầu khác ngoài cấu Phân tích trúc ngữ pháp: cú pháp –Tên “x” đã được định nghĩa chưa? –“x” là tên một biến hay một hàm? –“x” được định nghĩa ở đâu? Phân tích –Biểu thức “a+b” có nhất quán về kiểu ngữ nghĩa không? –… • Phân tích ngữ nghĩa trả lời các câu Sinh mã hỏi đó để làm rõ hơn ngữ nghĩa của chương trình. 09/20/23 6
- Nhiệm vụ của bộ phân tích ngữ nghĩa • Quản lý thông tin về các định danh (tên) – Hằng, biến, kiểu tự định nghĩa, chương trình con • Kiểm tra việc sử dụng các định danh – Phải được khai báo trước khi dùng – Phải được sự dụng đúng mục đích • Gán giá trị cho hằng, tính toán trên kiểu, thủ tục… – Đảm bảo tính nhất quán • Tên được khai báo chỉ một lần trong phạm vi • Các phần tử trong kiểu liệt kê (enum) là duy nhất Bảng ký hiệu 09/20/23 7
- Nhiệm vụ của bộ phân tích ngữ nghĩa • Kiểm tra kiểu dữ liệu cho toán tử – Toán tử % của C đòi hỏi toán hạng kiểu nguyên – Có thể yêu cầu chuyển kiểu bắt buộc (int2real) – Chỉ số của mảng phải nguyên • Kiểm tra sự tương ứng giữa tham số thực sự và hình thức – Số lượng tham số, tương ứng kiểu • Kiểm tra kiểu trả về của hàm.. Các biểu thức kiểu của ngôn ngữ 09/20/23 Bộ luật để định kiểu cho các cấu trúc 8
- Bảng ký hiệu • Lưu trữ thông tin về các định danh trong chương trình và các thuộc tính của chúng – Hằng: {tên, kiểu, giá trị} – Kiểu người dùng định nghĩa: {tên, kiểu thực tế} – Biến: {tên, kiểu} – Hàm: {tên, các tham số hình thức, kiểu trả về, các khai báo địa phương} – Thủ tục: {tên, các tham số hình thức, các khai báo địa phương) – Tham số hình thức: {tên, kiểu, tham biến/tham trị} 09/20/23 9
- Bảng ký hiệu Khi gặp một tên trong chương trình • Gặp trong giai đoạn khai báo – Đưa tên và các thông tin tương ứng vào bảng – Ví dụ: Const Max = 10; • Đưa Max vào bảng, với kiểu là constant, giá trị là 10; • Gặp trong câu lệnh – Đọc thông tin ra để sử dụng • Phân tích ngữ nghĩa: Sử dụng đúng mục đích không? – Ví dụ: Max := 20; Sai mục đích • Sinh mã: Kích thước bộ nhớ cấp phát cho tên – Ví dụ: int 2 bytes, float 4 byte 09/20/23 10
- Bảng ký hiệu trong KPL Trong chương trình dịch KPL, bảng ký hiệu được biểu diễn theo cấu trúc phân cấp PROGRAM test; test:PRG CONST c = 100; TYPE t = Integer; c: CST = 100 VAR v : t; FUNCTION f(x : t) : t; VAR y : t; t : TY = INT BEGIN y := x + 1; v: VAR : INT f := y; END; f : FN: INT INT BEGIN v := 1; x : PAR : INT WriteLn (f(v)); END. y : VAR : INT 09/20/23 11
- Xây dựng bảng ký hiệu Các thành phần struct SymTab_ { //Bảng ký hiệu // Chương trình chính Object program Object* program; Scope currentScope // Trỏ tới phạm vi hiện tại globalObjList ObjectNode Scope* currentScope; symtable // Các đối tượng toàn cục như // hàm WRITEI, WRITEC, WRITELN // READI, READC ObjectNode *globalObjectList; }; 09/20/23 12
- Xây dựng bảng ký hiệu Các thành phần // Phạm vi của một block struct Scope_ { //Danh sách các đối tượng trong block ObjectNode *objList; // Hàm, thủ tục, chương trình tương ứng block Object *owner; ObjectNode objList // Phạm vi bao ngoài owner Object Scope struct Scope_ *outer; outer }; Scope 09/20/23 13
- Xây dựng bảng ký hiệu • Bảng ký hiệu ghi nhớ block hiện đang duyệt trong biến currentScope • Mỗi khi dịch một hàm hay thủ tục, phải cập nhật giá trị của currentScope • void enterBlock(Scope* scope); • Mỗi khi kết thúc duyệt một hàm hay thủ tục phải chuyển lại currentScope ra block bên ngoài • void exitBlock(void); • Đăng ký một đối tượng vào block hiện tại • void declareObject(Object* obj); 09/20/23 14
- Kiểu enum TypeClass { TP_INT, ARRAY[100] OF ARRAY[50] OF Integer TP_ARRAY TP_CHAR, 100 TP_ARRAY TP_ARRAY elmntType 50 TP_INT }; Type elmntType N/A struct Type_ { Type N/A enum TypeClass typeClass; Type // Chỉ sử dụng cho kiểu mảng typeClass int arraySize; arraySize Type elementType struct Type_ *elementType; Type }; 09/20/23 15
- Hằng số struct ConstantValue_ { enum TypeClass type; union { int intValue; char charValue; }; }; 09/20/23 16
- Hằng số và kiểu Các hàm tạo kiểu Type* makeIntType(void); Type* makeCharType(void); Type* makeArrayType(int arraySize, Type* elementType); Type* duplicateType(Type* type) Các hàm tạo giá trị hằng số ConstantValue* makeIntConstant(int i); ConstantValue* makeCharConstant(char ch); ConstantValue* duplicateConstantValue(ConstantValue* v); 09/20/23 17
- Đối tượng //Thuộc tính của đối tượng trong bảng // Phân loại ký hiệu struct Object_ { enum ObjectKind { char name[MAX_IDENT_LEN]; OBJ_CONSTANT, enum ObjectKind kind; OBJ_VARIABLE, union { ConstantAttributes* constAttrs; OBJ_TYPE, VariableAttributes* varAttrs; OBJ_FUNCTION, TypeAttributes* typeAttrs; OBJ_PROCEDURE, FunctionAttributes* funcAttrs; OBJ_PARAMETER, ProcedureAttributes* procAttrs; OBJ_PROGRAM ProgramAttributes* progAttrs; }; ParameterAttributes* paramAttrs; }; }; 09/20/23 18
- Đối tượng (tiếp) ConstantAttributes name Object VariableAttributes; object kind TypeAttributes ObjectNode next …..Attrs FunctionAttributes ObjectNode Object ProcedureAttributes ProgramAttributes ParameterAttributes Ví du: Đối tượng: program BaiTap « BaiTap » OBJ_PRO ObjNode progAttrs scope objList Object Object ProgAttr owner Scope outer 09/20/23 Scope 19
- Thuộc tính của đối tượng struct ProgramAttributes_ { scope objList ObjNode struct Scope_ *scope; ProgAttr owner Object }; Scope outer struct ConstantAttributes_ { Scope ConstantValue* value; }; typeClass arraySize struct VariableAttributes_ { VarAttr Type type elementType Type *type; Type struct Scope_ *scope; scope ObjNode objList }; // Phạm vi; sử dụng cho sinh mã owner Object struct TypeAttributes_ { outer Scope Type *actualType; Scope }; 09/20/23 20
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng thực hành lập trình web 2 - Bài 1
9 p | 530 | 128
-
Hướng dẫn thực hành lập trình C trên Visual Studio
9 p | 1349 | 31
-
Bài giảng Kỹ thuật lập trình - Chương 3
16 p | 80 | 9
-
Bài giảng Thực hành chương 5: Cấu hình Group Policy để tự động map ổ đĩa mạng cho Client - Từ Thanh Trí
9 p | 110 | 9
-
Bài giảng Thực hành chương 3: Tạo User Account & cấu hình Home Folder Cho User Account
12 p | 159 | 8
-
Bài giảng Ngôn ngữ lập trình Pascal: Chương 6 - Thực hành Turbo Pascal
6 p | 133 | 6
-
Bài giảng Lập trình hướng đối tượng 1: Chương 3 - ThS. Thái Kim Phụng
13 p | 69 | 5
-
Bài giảng Hệ điều hành Linux - Bài 6: Quản lý tiến trình
15 p | 59 | 4
-
Bài giảng Thực hành cơ sở lập trình: Giới thiệu về IDE
18 p | 12 | 4
-
Bài giảng Thực hành chương trình dịch: Bài 5 - Phạm Đăng Hải
66 p | 26 | 4
-
Bài giảng Thực hành chương trình dịch: Bài 3 - Phạm Đăng Hải
32 p | 21 | 4
-
Bài giảng Thực hành chương trình dịch: Bài 1 - Phạm Đăng Hải
13 p | 18 | 4
-
Bài giảng Thực hành chương 1: Cài đặt Windows Server 2003 - Từ Thanh Trí
12 p | 88 | 4
-
Bài giảng Thực hành cơ sở lập trình: C Programming (Phần 1)
27 p | 11 | 4
-
Bài giảng Thực hành chương trình dịch: Bài 2 - Phạm Đăng Hải
20 p | 22 | 3
-
Bài giảng môn Tin học: Chương 1 - TS. Nguyễn Văn Hiệp
10 p | 49 | 3
-
Bài giảng C Programming introduction: Tuần 2 - Giới thiệu ngôn ngữ lập trình C
26 p | 10 | 2
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn