Bài giảng Lý thuyết ngôn ngữ lập trình

pdf 55 trang vanle 4920
Bạn đang xem 20 trang mẫu của tài liệu "Bài giảng Lý thuyết ngôn ngữ lập trình", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfbai_giang_ly_thuyet_ngon_ngu_lap_trinh.pdf

Nội dung text: Bài giảng Lý thuyết ngôn ngữ lập trình

  1. Bài giảng LÝLÝ THUYTHUYẾẾTT NGÔNNGÔN NGNGỮỮ LLẬẬPP TRÌNHTRÌNH Trường Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính Bài giảng môn Lý thuyết ngôn ngữ lập tr
  2. MMụụcc tiêutiêu mônmôn hhọọcc  Lý thuyết: Sinh viên nắm được các kiến thức cơ bản về ngôn ngữ lập trình, tổng quan về các loại ngôn ngữ lập trình  Kỹ năng: Sinh viên có thể viết các chương trình đơn giản bằng ngôn ngữ lập trình C Sinh viên có các kiến thức cơ bản làm nền tảng để tiếp thu, nghiên cứu các ngôn ngữ lập trình cụ thể sau này ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 2
  3. NNộộii dungdung  Các khái niệm về ngôn ngữ lập trình  Tiêu chuẩn đánh giá và phân loại ngôn ngữ lập trình  Giới thiệu sơ lược một số ngôn ngữ lập trình thông dụng  Giới thiệu tổng quan các giai đoạn của một quá trình biên dịch  Các khái niệm về thuật toán và lưu đồ thuật toán  Các thành phần cơ bản của ngôn ngữ lập trình C  Các vấn đề chính của ngôn ngữ lập trình: – Định nghĩa, đặc tả và cài đặt các kiểu dữ liệu – Biểu thức và phép gán – Các lệnh có cấu trúc, ngoại lệ và xử lý ngoại lệ – Chương trình con ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 3
  4. TTààii liliệệuu hhọọcc ttậậpp  Giáo trình, bài giảng – Giáo trình Lý thuyết ngôn ngữ lập trình (lưu hành nội bộ) – Bài giảng môn học Lý thuyết ngôn ngữ lập trình  Tài liệu tham khảo – Robert W.Sebesta, Concept of Programming Laguages, Seventh Edition; Pearson International Edition, 2006 ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 4
  5. NNộộii dungdung mônmôn hhọọcc Chương 1 Mở đầu Chương 2 Tổng quan về trình biên dịch Chương 3 Thuật toán và lưu đồ thuật toán Chương 4 Các thành phần cơ bản của ngôn ngữ lập trình C Chương 5 Kiểu dữ liệu Chương 6 Biểu thức và phép gán Chương 7 Các lệnh có cấu trúc Chương 8 Chương trình con ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 5
  6. Chương 1 MMỞỞ ĐĐẦẦUU Trường Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính Bài giảng môn Lý thuyết ngôn ngữ lập tr
  7. NNộộii dungdung ChươngChương 11 1.1. Lập trình máy tính 1.1.1. Khái niệm 1.1.2. Các lĩnh vực ứng dụng 1.2. Ngôn ngữ lập trình 1.2.1. Khái niệm 1.2.2. Vai trò và lợi ích của việc nghiên cứu ngôn ngữ lập trình 1.2.3. Tiêu chuẩn đánh giá ngôn ngữ lập trình 1.2.4. Phân loại 1.2.5. Môi trường lập trình 1.3. Giới thiệu một số ngôn ngữ lập trình thông dụng ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 7
  8. 1.11.1 LLậậpp trtrììnhnh mmááyy ttíínhnh  Khái niệm – Lập trình máy tính là một cách nghĩ về các vấn đề – Biên dịch thành những chỉ thị để máy tính thực thi – Sản phẩm là các chương trình  Chương trình – Một chương trình trong tin học là một tập hợp riêng biệt các hoạt động có thứ tự cho một máy tính thực hiện – Chương trình bao gồm một chuỗi các chỉ thị lần lượt mà máy tính phải tuân theo – Máy tính nhận một chỉ thị và thực thi, rồi nhận chỉ thị tiếp theo ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 8
  9. 1.11.1 LLậậpp trtrììnhnh mmááyy ttíínhnh ((tttt))  Các lĩnh vực ứng dụng – Đa dạng: từ điều khiển các thiết bị năng lượng hạt nhân đến cung cấp trò chơi trên máy điện thoại di động – Theo Robert W.Sebesta, có thể chia thành các lĩnh vực ứng dụng:  Khoa học  Kinh doanh  Trí tuệ nhân tạo  Lập trình hệ thống  Phần mềm web ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 9
  10. 1.2 Ngôn ngữ lập trình  Khái niệm – Máy tính gồm – Phần cứng: các thiết bị điện tử – Phần mềm: các chương trình được tạo ra bằng ngôn ngữ lập trình – Ngôn ngữ lập trình (NNLT) là ngôn ngữ dùng để viết các chương trình cho máy tính – Là một hệ thống được ký hiệu hóa để mô tả những tính toán (qua máy tính) trong một dạng mà cả con người và máy đều có thể đọc và hiểu được  Tính chất – Có từ vựng – Có cú pháp và ngữ nghĩa ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 10
  11. 1.2 Ngôn ngữ lập trình (tt)  Hai điều kiện cơ bản: – Dễ hiểu và dễ sử dụng đối với người lập trình – Mô tả một cách đầy đủ và rõ ràng các tiến trình  Lập trình – Thao tác nhằm kiến tạo nên các chương trình máy tính thông qua các ngôn ngữ lập trình – Còn gọi là quá trình mã hoá thông tin tự nhiên thành ngôn ngữ máy – Quá trình này còn được gọi là là "viết mã“ ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 11
  12. 1.2 Ngôn ngữ lập trình (tt)  Mã nguồn của chương trình: – Những chỉ thị góp phần tạo nên chương trình được gọi là mã nguồn của chương trình – Mỗi NNLT cũng chính là một chương trình, được dùng để tạo nên các chương trình khác  Biên dịch – Thao tác chuyển từ mã nguồn thành chuỗi các chỉ thị máy tính – Có hai loại: Phần mềm thông dịch và phần mềm biên dịch ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 12
  13. 1.2 Ngôn ngữ lập trình (tt)  Phần mềm thông dịch – Là một chương trình phần mềm – Đọc hiểu mã nguồn của một ngôn ngữ ban đầu – Ra lệnh cho máy tính tiến hành các tính toán dựa theo cú pháp của ngôn ngữ này  Phần mềm biên dịch – Là một chương trình phần mềm – Đọc hiểu mã nguồn của một ngôn ngữ ban đầu – Chuyển dịch mã nguồn này sang dạng mã mới thuộc về ngôn ngữ cấp thấp hơn ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 13
  14. 1.2 Ngôn ngữ lập trình (tt)  Ngôn ngữ cấp thấp nhất (ngôn ngữ máy) – Chuỗi các chỉ thị máy tính có thể được thực hiện trực tiếp bởi chính máy tính – Các chỉ thị được viết dưới dạng mã nhị phân (0 hoặc 1)  Lời chú thích – Mã của chương trình nguồn thường gây khó khăn cho người đọc – Nên dùng các chú thích trong lúc lập trình – Giúp người khác đọc và hiểu được các mã nguồn ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 14
  15. 1.2 Ngôn ngữ lập trình (tt)  Các giai đoạn xây dựng phần mềm (công nghệ phần mềm): – Xác định – Hiểu rõ các yêu cầu của khách hàng – Kết quả là mô hình thế giới thực được phản ánh thông qua một tài liệu đặc tả yêu cầu – Phân tích – Xác định chính xác hệ thống sẽ làm những gì – Kết quả là một tài liệu đặc tả chức năng – Thiết kế – Xác định chính xác hệ thống sẽ làm việc như thế nào – Kết quả là một tài liệu đặc tả thiết kế. Người thực hiện sẽ căn cứ vào đó để tạo ra phần mềm ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 15
  16. 1.2 Ngôn ngữ lập trình (tt)  Các giai đoạn xây dựng phần mềm (tt): – Cài đặt – Thực hiện cách giải quyết vấn đề đã được đề xuất bằng một NNLT – Kết quả là một chương trình máy tính – Tích hợp và kiểm thử – Ghép nối các bộ phận của hệ thống và kiểm tra xem hệ thống có được thực hiện đúng theo thiết kế không – Chấp nhận – Do các chuyên viên tin học cùng với khách hàng tiến hành, nhằm xác nhận hệ thống bảo đảm các yêu cầu của người sử dụng – Vận hành khai thác – Hệ thống được triển khai để sử dụng ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 16
  17. 1.2 Ngôn ngữ lập trình (tt)  Lợi ích của việc nghiên cứu NNLT – Tăng khả năng diễn đạt các ý tưởng – “Độ sâu” tư duy bị ảnh hưởng bởi năng lực diễn đạt của ngôn ngữ – Ngôn ngữ lập trình bị giới hạn trong các kiểu của cấu trúc điều khiển, cấu trúc dữ liệu và sự trừu tượng hoá – Các hình thức của thuật toán xây dựng cũng đều có giới hạn tương tự – Tạo nền tảng để lựa chọn NNLT phù hợp với một dự án – Java cho các dự án lập trình truyền thông – Lập trình logic cho các dự án về trí tuệ nhân tạo – Dễ dàng hơn khi học một NNLT mới – Rất nhiều ngôn ngữ có chung cú pháp (khác nhau về cách viết) – Có chung các kiểu dữ liệu (khác nhau về tên gọi) ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 17
  18. 1.2 Ngôn ngữ lập trình (tt)  Lợi ích của việc nghiên cứu NNLT (tt) – Hiểu sâu sắc hơn ý nghĩa của các cài đặt bên trong NNLT – Các ngôn ngữ nói chung đều cung cấp những công cụ đặc biệt để tạo ra các tiện ích cho lập trình viên – Sử dụng không đúng đắn có thể gây ra sai lầm lớn – Ví dụ: Có thể cài đặt một giải thuật đẹp và hiệu quả bằng đệ quy, nhưng nếu dùng không đúng sẽ gây lãng phí thời gian – Tăng vốn kinh nghiệm cho lập trình viên – Tạo tiền đề cho việc nghiên cứu và thiết kế một NNLT mới ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 18
  19. 1.2 Ngôn ngữ lập trình (tt)  Tiêu chuẩn đánh giá NNLT – Tính dễ đọc – Tính dễ viết – Độ tin cậy – Chi phí  Tính dễ đọc: là sự dễ dàng đọc hiểu một chương trình – Tính giản dị: Ngôn ngữ có ít các thành phần cơ sở – Cấu trúc điều khiển: Cho phép viết các chương trình sáng sủa, dễ đọc, dễ hiểu – Kiểu và cấu trúc dữ liệu: Góp phần đánh giá một ngôn ngữ có dễ đọc hay không – Cú pháp: Ảnh hưởng đến sự dễ đọc hiểu của chương trình ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 19
  20. 1.2 Ngôn ngữ lập trình (tt)  Ví dụ: So sánh hai đoạn chương trình in ra màn hình 10 số tự nhiên đầu tiên Viết bằng BASIC Viết bằng C 10 i=1; for (i =1; i 10 THEN GOTO 60; 30 PRINT i ; 40 i=i+1; 50 GOTO 20; 60 PRINT “In xong”; ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 20
  21. 1.2 Ngôn ngữ lập trình (tt)  Tính dễ viết: Là khả năng sử dụng ngôn ngữ để viết một chương trình cho một vấn đề nào đó một cách dễ dàng hay không – Sự giản dị: Nếu một ngôn ngữ có quá nhiều cấu trúc thì một số người lập trình sẽ không quen sử dụng hết tất cả chúng – Hỗ trợ trừu tượng: Là khả năng định nghĩa và sử dụng các cấu trúc hoặc các phép toán phức tạp cho phép bỏ qua các chi tiết. Trừu tượng hóa làm cho chương trình sáng sủa hơn – Khả năng diễn đạt: Cung cấp cho người lập trình những công cụ để có thể nghĩ sao thì viết chương trình như vậy ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 21
  22. 1.2 Ngôn ngữ lập trình (tt)  Độ tin cậy: Là khả năng của ngôn ngữ hỗ trợ người lập trình tạo ra các chương trình đúng đắn – Kiểm tra kiểu: Là kiểm tra lỗi về kiểu dữ liệu của chương trình trong giai đoạn dịch hoặc trong khi thực hiện – Xử lý ngoại lệ (Exception Handing): Cho phép phát hiện lỗi trong thời gian thực hiện, sửa chữa và tiếp tục thực hiện mà không phải dừng chương trình – Sự lắm tên (Aliasing): Có hai hay nhiều tên cùng liên kết tới một ô nhớ. Sự lắm tên có thể làm giảm độ tin cậy ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 22
  23. 1.2 Ngôn ngữ lập trình (tt)  Chi phí cũng thường được quan tâm như một tiêu chuẩn để đánh giá ngôn ngữ, được hiểu là cả tiền bạc và thời gian – Chi phí đào tạo lập trình viên sử dụng ngôn ngữ: phụ thuộc vào sự giản dị của ngôn ngữ – Chi phí cài đặt chương trình: phụ thuộc vào tính dễ viết của ngôn ngữ – Chi phí dịch chương trình – Chi phí thực hiện chương trình – Chi phí bảo trì chương trình – Chi phí mua trình biên dịch ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 23
  24. 1.2 Ngôn ngữ lập trình (tt)  Phân loại NNLT – Theo tiến trình lịch sử phát triển  Ngôn ngữ máy, Hợp ngữ, Ngôn ngữ cấp cao, Ngôn ngữ cấp rất cao – Theo mục tiêu của ngôn ngữ  Đa dụng, Nhúng, Lập trình web, – Theo cách thức  Mã máy, Thông dịch, Lai – Theo phương pháp  Lập trình tuyến tính, Lập trình có cấu trúc, Lập trình hướng đối tượng, Lập trình trực quan, Lập trình logic, ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 24
  25. 1.2 Ngôn ngữ lập trình (tt)  Phân loại NNLT theo tiến trình lịch sử phát triển – Ngôn ngữ máy (machine language) – Hợp ngữ (assembly language) – Ngôn ngữ cấp cao (HLL - High level language) – Ngôn ngữ cấp rất cao (VHLL – Very High Level Language) ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 25
  26. 1.2 Ngôn ngữ lập trình (tt)  Ngôn ngữ máy (machine language) – Là các chỉ thị dưới dạng nhị phân – Can thiệp trực tiếp vào các mạch điện tử – Có thể được thực hiện ngay không cần qua bước trung gian nào – Chương trình viết bằng ngôn ngữ máy dễ sai sót, cồng kềnh và khó đọc, khó hiểu ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 26
  27. 1.2 Ngôn ngữ lập trình (tt)  Hợp ngữ (assembly language) – Là một bước tiến vượt bậc đưa ngôn ngữ lập trình thoát ra khỏi ngôn ngữ máy khó hiểu – Xuất hiện vào những năm 1950 – Đưa ra khái niệm biến (variable), có thể gán một ký hiệu cho một địa chỉ – Biểu biễn mã phép toán dưới dạng phát biểu (lệnh) thay vì dưới dạng nhị phân – Lệnh gồm hai phần: mã lệnh (tựa tiếng Anh) chỉ phép toán cần thực hiện, và tên biến chỉ địa chỉ chứa toán hạng – Ðể máy thực hiện được thì chương trình phải được dịch sang ngôn ngữ máy (Assembler) ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 27
  28. 1.2 Ngôn ngữ lập trình (tt)  Ngôn ngữ cấp cao (HLL - High level language) – Được tạo ra và phát triển nhằm phản ánh cách người lập trình nghĩ và làm – Rất gần với ngôn ngữ con người (Anh ngữ) nhưng chính xác như ngôn ngữ toán học – Việc lập trình trở nên phổ biến – Việc lập trình cũng có nhiều khuynh hướng: lập trình cấu trúc, lập trình hướng đối tượng, lập trình logic, lập trình hàm – Một chương trình viết bằng ngôn ngữ cấp cao được gọi là chương trình nguồn (source programs) – Ðể máy tính "hiểu" và thực hiện được các lệnh thì phải có một chương trình dịch để dịch chương trình nguồn (viết bằng ngôn ngữ cấp cao) thành chương trình đích ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 28
  29. 1.2 Ngôn ngữ lập trình (tt)  NN cấp rất cao (VHLL – Very High Level Language) – “Hướng đến con người” – Được thiết kế để phát triển các ứng dụng chuyên biệt mà không đòi hỏi nhiều kiến thức về lập trình – Một là các NNLT tương tác mạnh như ngôn ngữ đánh dấu (HTML, DHTML, XML) và ngôn ngữ mô hình (VRML) dùng để tạo trang WEB và nội dung đa phương diện – Hai là các ngôn ngữ kịch bản như Javascript dùng để viết các chương trình nhỏ đi kèm các trang WEB để tạo hiệu ứng động và tương tác ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 29
  30. 1.2 Ngôn ngữ lập trình (tt)  Phân loại theo mục tiêu của ngôn ngữ – Đa dụng: như C, perl, C++, Java, – Nhúng: Như Ch, Ada, – Lập trình web: PHP, Java Script, Cold Fusion, – Riêng: Như AutoLisp, Mathematica, ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 30
  31. 1.2 Ngôn ngữ lập trình (tt)  Phân loại theo cách thức – Mã máy: Thường gặp như C, C++, – Thông dịch: Giữ nguyên dưới dạng file văn bản, được thông dịch sang mã máy khi chạy như Perl, PHP, – Lai: Ví dụ Java biên dịch ra Java Byte code, khi chạy mới thông dịch sang mã máy, như vậy tạo ra khả năng "viết một nơi chạy mọi nơi" của Java. Một ví dụ khác là .NET ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 31
  32. 1.2 Ngôn ngữ lập trình (tt)  Phân loại theo phương pháp – Đục lỗ: Vào thời kỳ đầu, đục các thẻ đưa cho máy tính đọc – Tuyến tính: Phát triển ở mức cao hơn thẻ đục lỗ, nhưng còn rất thô sơ (assembly) – Lập trình có cấu trúc:  Cho phép diễn tả thuật toán một cách dễ dàng  Áp dụng phương pháp "Chia để trị" giúp tránh lỗi khi viết những chương trình lớn, phức tạp  Dựa trên quan điểm: một công việc lớn bao giờ cũng có thể phân tích được thành những công việc nhỏ hơn  Phân tích đến mức đơn giản, có thể thực hiện được một cách dễ dàng  Phương pháp này rất phổ biến và vẫn áp dụng rất nhiều trong hiện tại như Pascal, C ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 32
  33. 1.2 Ngôn ngữ lập trình (tt)  Phân loại theo phương pháp (tt) – Hướng đối tượng:  Xem mọi thứ là đối tượng, quá trình giải quyết công việc là quá trình các đối tượng tương tác với nhau  Ví dụ: C++, Java, Ada, – Lập trình logic:  Cho chương trình biết sẽ làm cái gì chứ không phải làm như thế nào  Toàn bộ các câu lệnh chỉ đơn giản là đúng hoặc sai  Ví dụ: ngôn ngữ Prolog ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 33
  34. 1.2 Ngôn ngữ lập trình (tt)  Phân loại theo phương pháp (tt) – Lập trình hàm:  Toàn bộ các lệnh và mọi thứ đều được đưa về hàm.  Cũng là ngôn ngữ dạng mô tả  Ví dụ: ngôn ngữ LISP – Lập trình trực quan:  Hỗ trợ tạo mã nguồn một cách trực quan.  Ví dụ: ngôn ngữ Visual Basic – Ngôn ngữ đánh dấu:  Ví dụ: ngôn ngữ HTML ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 34
  35. 1.2 Ngôn ngữ lập trình (tt)  Môi trường lập trình – Là công cụ giúp chúng ta viết mã cho chương trình – Một công cụ viết mã cổ điển nhưng hiệu quả là Notepad – Môi trường lập trình là những công cụ tương ứng với từng ngôn ngữ lập trình – Hỗ trợ cho chúng ta những dòng mã tự sinh để giảm bớt chi phí lập trình ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 35
  36. 1.3 Giới thiệu một số NNLT thông dụng  Chọn công cụ cho phù hợp với công việc cần làm – Dùng ASSEMBLY để viết các chương trình truy cập đến các cấp thấp của máy tính – Để tạo hệ cửa sổ giao tiếp đồ hoạ, dùng NNLT hướng đối tượng – Truy cập CSDL, dùng ngôn ngữ truy vấn – Một số ngôn ngữ lập trình đang phổ biến hiện nay: PASCAL, C, C++, JAVA, VISUAL BASIC . ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 36
  37. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình PASCAL – Do giáo sư Niklaus Wirth thiết kế năm 1970 – Mục đích ban đầu: giảng dạy ý niệm lập trình có cấu trúc – Do tính ưu việt nên PASCAL đã được sử dụng rộng rãi – Dùng ngôn ngữ sát với ngôn ngữ tự nhiên nên nó thân thiện với người lập trình – Gọn, dễ nhớ, khả năng truy cập cấp thấp, và các cấu trúc dữ liệu đa dạng ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 37
  38. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình PASCAL (tt) – Hỗ trợ khả năng đưa các chương trình viết bằng ASSEMBLY vào chương trình, khả năng đồ hoạ và hướng đối tượng – Là ngôn ngữ lập trình có cấu trúc:  Cấu trúc của dữ liệu thể hiện qua phần mô tả, có một số kiểu dữ liệu và các phép toán được định nghĩa sẵn. Từ đó, có thể xây dựng các kiểu dữ liệu phức tạp hơn  Cấu trúc của các toán tử thể hiện ở chỗ bên trong các toán tử thực hiện một động tác, còn có các toán tử thực hiện nhiều động tác  Cấu trúc trong công cụ thủ tục thể hiện thông qua khả năng phân tích chương trình thành các modul độc lập và lời gọi đệ quy ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 38
  39. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình PASCAL (tt) – Không phân biệt chữ hoa và chữ thường → thoải mái hơn trong việc viết các câu lệnh và đặt tên cho các đối tượng – Việc dịch một chương trình được thực hiện bằng một trình biên dịch  Nếu có lỗi cú pháp thì mã máy sẽ không được sinh ra  Nếu không, sau khi dịch xong sẽ nhận được một phiên bản có khả năng thực thi – Thích hợp để giảng dạy lập trình và cho những người mới học lập trình ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 39
  40. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C – Được phát triển từ ngôn ngữ B trên máy UNIX – Đến nay, ANSI ban hành chuẩn về C – C không phải là ngôn ngữ lập trình có cấu trúc chính thống: không cho phép các khối lồng nhau – Là ngôn ngữ cấp trung vì nó cho phép thao tác trên các bit, byte, và địa chỉ – Kết hợp các yếu tố mềm dẻo của ngôn ngữ bậc cao và khả năng điều khiển mạnh của ASSEMBLY – Do vậy, C tỏ ra thích hợp với lập trình hệ thống ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 40
  41. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C (tt) – Chương trình viết bằng C là tập hợp các hàm riêng biệt, giúp che giấu mã và dữ liệu – Hàm được viết bởi những người lập trình khác nhau, không ảnh hưởng đến nhau và có thể được biên dịch riêng biệt trước khi ráp nối thành chương trình – C thoáng hơn PASCAL, chẳng hạn C không kiểm tra kiểu khi chạy, điều này do người lập trình đảm nhiệm ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 41
  42. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C (tt) – C có tính tương thích cao – Chương trình viết bằng C cho một loại máy hoặc hệ điều hành này có thể chuyển dễ dàng sang loại máy hoặc hệ điều hành khác – Chương trình được viết bằng C thường có được sự tối ưu như chạy với tốc độ cao và tiết kiệm bộ nhớ – C chỉ thích hợp với những chương trình hệ thống hoặc những chương trình đòi hỏi tốc độ – Với bài toán lớn và phức tạp, C cũng rất khó kiểm soát chương trình ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 42
  43. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C++ – Được phát triển từ ngôn ngữ C – Có thể coi C++ là một cải tiến của C – Nó mang đầy đủ các đặc tính của C – Một chương trình viết bằng C có thể biên dịch được bằng trình biên dịch của C++ – Ở những phiên bản đầu tiên, mã nguồn C++ được dịch sang mã nguồn C, rồi từ mã nguồn C tiếp tục được biên dịch ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 43
  44. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C++ (tt) – Là ngôn ngữ lập trình hướng đối tượng – Nó có tính kế thừa, tính đóng gói và tính đa hình – Nhưng không phải là ngôn ngữ hướng đối tượng hoàn toàn – Là ngôn ngữ "đa hướng“: C++ vừa hỗ trợ lập trình hướng sự kiện vừa hỗ trợ lập trình hướng đối tượng ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 44
  45. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C++ (tt) – Kết hợp những ý tưởng hay nhất của lập trình có cấu trúc (phân chia bài toán thành các nhóm nhỏ có quan hệ với nhau) và lập trình hướng đối tượng (mỗi nhóm con đó là một đối tượng chứa các lệnh và dữ liệu riêng của nó) – Đưa vào các khái niệm hàm ảo, chồng hàm, chồng toán tử cho phép tạo ra các kiểu dữ liệu trừu tượng, hỗ trợ đa thừa kế ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 45
  46. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C++ (tt) – Mục tiêu của C++ là tiếp cận những ý tưởng của phương pháp luận hướng đối tượng và trừu tượng dữ liệu – Các đặc tính của C ++ cho phép người lập trình xây dựng những thư viện phần mềm có chất lượng cao phục vụ những đề án lớn – Thích hợp cho việc xây dựng những chương trình lớn như các hệ soạn thảo, chương trình dịch, các hệ quản trị cơ sở dữ liệu, các hệ truyền thông, ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 46
  47. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình Java – Năm 1990, bởi nhóm phát triển của Sun Microsystem – Có nhiệm vụ viết phần mềm hệ thống để nhúng vào các sản phẩm điện tử – Khắc phục một số hạn chế của C++ để tạo ra ngôn ngữ lập trình JAVA – Do được phát triển từ C++ nên JAVA rất giống C++ – JAVA là ngôn ngữ hướng đối tượng hoàn toàn, còn C++ là ngôn ngữ đa hướng (ngôn ngữ lai) ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 47
  48. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình Java (tt) – Là ngôn ngữ hướng đối tượng: các modul (lớp) có thể thay đổi và được xây dựng trước, có thể gọi ra để thực hiện những nhiệm vụ cụ thể – Đơn giản: JAVA đã được lược bỏ các tính năng khó nhất của C++. Trong JAVA không có các con trỏ, không hỗ trợ chồng toán tử (Overloading), không có tiền xử lý – Đa luồng: JAVA cho phép xây dựng các trình ứng dụng, trong đó nhiều quá trình có thể xảy ra đồng thời ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 48
  49. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình Java (tt) – Hiểu mạng: JAVA được viết để hoạt động trên mạng và có các thủ tục để có thể quản lý các giao thức TCP/IP, FTP, HTTP – JAVA cho phép tạo ra các trang Web động, các ứng dụng nhúng – An toàn: Có những phần hạn chế được cài đặt sẵn, nhằm hạn chế các chương trình JAVA thực hiện việc ghi vào ổ cứng hoặc cho phép vi rút xâm nhập vào từ mạng – Độc lập với cấu trúc máy: Là thuộc tính đặc sắc nhất của JAVA, các ứng dụng được viết bằng JAVA có thể dùng được trên hầu hết mọi máy tính ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 49
  50. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình Visual Basic – Được phát triển bởi Microsoft – Cung cấp phương pháp phát triển các ứng dụng trên Windows nhanh và dễ nhất – Cung cấp môi trường tích hợp, nơi người lập trình có thể sử dụng các công cụ để tạo ra giao diện người sử dụng một cách nhanh chóng – Dễ dàng tạo ra mã để trả lời lại các tác động từ phía người sử dụng ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 50
  51. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình Visual Basic (tt) – Cung cấp cả kỹ thuật lập trình hướng sự kiện và kỹ thuật lập trình hướng đối tượng – Môi trường phát triển của Visual Basic có những công cụ soạn thảo và gỡ rối tinh vi – Cho phép người lập trình gắn mã với giao diện một cách nhanh chóng cho mỗi sự kiện – Visual Basic hỗ trợ tạo ra một giao diện nhanh nhất nhưng lại hạn chế về tốc độ ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 51
  52. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C# – C# là một ngôn ngữ rất đơn giản, với khoảng 80 từ khoá và hơn mười kiểu dữ liệu xây dựng sẵn – C# có tính diễn đạt cao – C# hỗ trợ lập trình có cấu trúc, hướng đối tượng, hướng thành phần – Trọng tâm của ngôn ngữ hướng đối tượng là lớp. Lớp định nghĩa kiểu dữ liệu mới, cho phép mở rộng ngôn ngữ theo hướng cần giải quyết ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 52
  53. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C# (tt) – C# có những từ khoá dành cho việc khai báo lớp, phương thức, thuộc tính (property) mới – C# hỗ trợ đầy đủ khái niệm quan trọng trong lập trình hướng đối tượng: đóng gói, thừa kế, đa hình – Định nghĩa lớp trong C# không đòi hỏi tách rời tập tin tiêu đề với tập tin cài đặt như C++ – C# hỗ trợ kiểu sưu liệu mới, cho phép sưu liệu trực tiếp trong tập tin mã nguồn. Khi biên dịch sẽ tạo tập tin sưu liệu theo định dạng XML ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 53
  54. 1.3 Một số NNLT thông dụng (tt)  Ngôn ngữ lập trình C# (tt) – C# hỗ trợ khái niệm giao diện (interfaces) tương tự như Java cho phép đa thừa kế – C# có kiểu cấu trúc (struct), là kiểu hạng nhẹ và bị giới hạn – Cấu trúc không thể thừa kế lớp hay được thừa kế nhưng có thể thực hiện giao diện – C# cung cấp những đặc trưng lập trình hướng thành phần như property, sự kiện và dẫn hướng khai báo (được gọi là attribute) – C# cho phép truy cập trực tiếp bộ nhớ dùng con trỏ như C++, nhưng vùng mã đó được xem là không an toàn ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 54
  55. 1.4 Câu hỏi ôn tập 1. Vai trò của ngôn ngữ lập trình trong công nghệ phần mềm là gì? 2. Nêu các lợi ích của việc nghiên cứu ngôn ngữ lập trình. 3. Nêu các tiêu chuẩn để đánh giá một ngôn ngữ lập trình. 4. Nêu các yếu tố ảnh hưởng đến tính dễ đọc. 5. Các yếu tố ảnh hưởng đến tính dễ viết là gì? 6. Các yếu tố nào ảnh hưởng đến độ tin cậy? 7. Chi phí của ngôn ngữ lập trình bao gồm những gì? ờng Cao đẳng CNTT HN Việt – Hàn Khoa Khoa học máy tính 55