Bài giảng Kỹ thuật lập trình - Bài 1: Giới thiệu môn học - Đào Trung Kiên

pdf 18 trang ngocly 3710
Bạn đang xem tài liệu "Bài giảng Kỹ thuật lập trình - Bài 1: Giới thiệu môn học - Đào Trung Kiên", để 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_ky_thuat_lap_trinh_bai_1_gioi_thieu_mon_hoc_dao_tr.pdf

Nội dung text: Bài giảng Kỹ thuật lập trình - Bài 1: Giới thiệu môn học - Đào Trung Kiên

  1. Bài 1: Giới thiệu môn học 1 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  2. Giới thiệu  Kỹ thuật lập trình C/C++ (EE3490)  Lý thuyết + Bài tập (0.1) + Bài tập lớn (0.2) + Thi cuối kỳ (0.7)  Trình biên dịch: MS Visual C++  Sách tham khảo:  The C Programming Language – 2nd Edition, Brian W. Kerninghan & Dennis M. Ritchie, Prentice-Hall,1998  The C++ Programming Language – 3rd Edition, Bjarne Stroustrup, Addison-Wesley, 1997  Website:  2 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  3. Nội dung môn học  Mở đầu (1 tuần)  Quá trình phát triển của các ngôn ngữ lập trình (NNLT)  Giới thiệu ngôn ngữ C và C++  Lập trình cấu trúc (7 tuần)  Phân tích và thiết kế  Biến, dữ liệu, kiểu, toán tử  Cấu trúc điều khiển  Quản lý bộ nhớ  Hàm, thư viện  Cấu trúc dữ liệu  Lập trình vào ra 3 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  4. Nội dung môn học (tiếp)  Lập trình hướng đối tượng (3 tuần)  Khái niệm OOP  Lớp và đối tượng  Kế thừa  Cấu trúc dữ liệu  Lập trình vào ra  Lập trình khái quát (2 tuần)  Khuôn mẫu hàm, lớp  Thư viện STL 4 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  5. Tổng quan 5 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  6. Khái niệm về chương trình và lập trình  Chương trình: tập các lệnh máy tính phải tuân theo  Phần mềm: tập hợp các chương trình  Hệ điều hành (HĐH):  là một phần mềm  cho phép người dùng thao tác với máy tính  quản lý tài nguyên (CPU, bộ nhớ, phần cứng/mềm, )  chạy chương trình  Thuật toán: chuỗi lệnh có thứ tự để giải quyết một vấn đề nhất định  Trình biên dịch: là chương trình cho phép chuyển đổi mã nguồn thành mã máy 6 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  7. Mã lệnh và dữ liệu  Máy tính chỉ hiểu mã nhị phân (byte, bit)  Một mã lệnh có thể có mã 01000001  Chữ cái ‘A’ có mã 01000001  Số 65 có mã 01000001  Làm thế nào máy tính hiểu 01000001 biểu diễn gì:  Phụ thuộc vào mã lệnh đang chạy là gì  Người viết chương trình phải hiểu vùng nhớ đang truy xuất chứa gì  Bộ nhớ trong của máy tính chứa cả dữ liệu và mã lệnh của chương trình khi chạy 7 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  8. Ngôn ngữ lập trình  Là ngôn ngữ được con thiết kế dùng để tạo ra những chương trình chạy trên máy tính theo ý đồ mong muốn  Quá trình phát triển:  Mã máy: dùng trực tiếp mã nhị phân, không cần biên dịch, phụ thuộc và bộ vi xử lý  Thế hệ thứ 2 (hợp ngữ): cần biên dịch, có thể đọc hiểu được, phụ thuộc và bộ vi xử lý  Thế hệ thứ 3 (cấu trúc): cấu trúc điều khiển, kiểu dữ liệu, đóng gói. VD: Fortran, C, C++, Basic, Pascal, COBOL,  Thế hệ thứ 4: nâng cao hiệu quả nhưng giảm các yếu tố dễ gây lỗi, cú pháp gần gũi hơn với ngôn ngữ nói. VD: SQL, LabVIEW, ColdFusion, 8 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  9. Quá trình phát triển phần mềm  Vòng đời của phần mềm:  Phân tích yêu cầu của bài toán (problem definition)  Thiết kế phần mềm (design)  Cài đặt thuật toán (coding)  Bảo trì, cập nhật và phát triển tiếp  Lỗi thời  Thử nghiệm: là quá trình kiểm tra sự hoạt động các tính năng của phần mềm  Gỡ lỗi: là quá trình tìm ra nguyên nhân của lỗi, và sửa nó 9 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  10. Lỗi chương trình  Lỗi cú pháp (lỗi biên dịch):  Do viết chương trình không tuân theo cú pháp quy định  Được phát hiện bởi trình biên dịch  Chú ý: đôi khi lỗi không được phát hiện vì bị hiểu sai sang cú pháp khác  Lỗi khi chạy (runtime errors):  Khi chương trình chạy vi phạm những điều kiện cho phép  Được phát hiện khi chạy  Lỗi logic:  Do thuật toán sai  Máy tính không phát hiện 10 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  11. Giới thiệu ngôn ngữ C và C++ 11 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  12. Lịch sử ngôn ngữ C  Ra đời trong những năm 1970, gắn liền với sự phát triển của HĐH Unix. Tác giả: Dennis Ritchie  Mục tiêu:  Đề cao tính hiệu quả  Có khả năng truy xuất phần cứng ở cấp thấp  Ngôn ngữ có cấu trúc (thay cho lập trình bằng hợp ngữ)  C là ngôn ngữ trung gian giữa cấp thấp  Có khả năng truy xuất bộ nhớ trực tiếp  Cú pháp ngắn gọn, ít từ khoá  và cấp cao  Không phụ thuộc phần cứng  Cấu trúc, hàm, khả năng đóng gói  Kiểm tra kiểu dữ liệu 12 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  13. Lịch sử ngôn ngữ C++  Ra đời năm 1979 bằng việc mở rộng ngôn ngữ C. Tác giả: Bjarne Stroustrup  Mục tiêu:  Thêm các tính năng mới  Khắc phục một số nhược điểm của C  Bổ sung những tính năng mới so với C:  Lập trình hướng đối tượng (OOP)  Lập trình tổng quát (template)  Nhiều tính năng nhỏ giúp lập trình linh hoạt hơn nữa (thêm kiểu bool, khai báo biến bất kỳ ở đâu, kiểu mạnh, định nghĩa chồng hàm, namespace, xử lý ngoại lệ, ) 13 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  14. Biên dịch chương trình C/C++  Là quá trình chuyển đổi từ mã nguồn (do người viết) thành chương trình ở dạng mã máy để có thể thực thi được Mã nguồn Mã biên dịch Trình biên dịch file1.c file1.obj Mã nguồn Mã biên dịch Trình biên dịch file2.c file2.obj Thư viện Trình liên kết Chương trình chạy a.exe 14 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  15. Biên dịch chương trình C/C++ (tiếp)  Cho phép dịch từng file riêng rẽ giúp:  Dễ phân chia và quản lý từng phần của chương trình  Khi cần thay đổi, chỉ cần sửa đổi file liên quan giảm thời gian bảo trì, sửa đổi  Chỉ cần dịch lại những file có thay đổi khi cần thiết giảm thời gian dịch  Các trình biên dịch hiện đại còn cho phép tối ưu hoá dữ liệu và mã lệnh  Một số trình biên dịch thông dụng: MS Visual C++, gcc/g++, clang, Intel C++ Compiler, Watcom C/C++, 15 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  16. Tại sao chọn C/C++  Ưu điểm:  Hiệu quả  Linh hoạt, khả năng tuỳ biến cao  Được hỗ trợ rộng rãi  trên các môi trường khác nhau  nhiều thư viện và công cụ sẵn có  Nhược điểm:  Ngôn ngữ [quá] phức tạp  Khó kiểm soát lỗi hơn so với các ngôn ngữ bậc cao (Java, .NET, script, ), nhất là nguyên nhân từ sử dụng con trỏ 16 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  17. Một vài điểm chú ý về ngôn ngữ C/C++  Cú pháp có phân biệt chữ hoa/thường: int, Int, INT là hoàn toàn khác nhau  Dấu ; dùng để phân tách các câu lệnh đơn  Dấu { } để quy định một khối câu lệnh  Không được đặt tên biến/hằng/hàm trùng với từ khoá có sẵn (void, int, char, struct, const, )  Trong một khối lệnh không có cấu trúc định hướng (if, for, while, ) thì các lệnh sẽ thực hiện tuần tự từ trên xuống  Chú thích:  trong C bằng: /* */  trong C++ có thêm ký hiệu // để chú thích đến hết dòng 17 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội
  18. Giới thiệu MS Visual C++  Là một môi trường tích hợp (IDE), trợ giúp:  Viết chương trình  Biên dịch  Gỡ lỗi (debug)  Làm ví dụ 18 EE3490: Kỹ thuật lập trình – HK1 2017/2018 TS. Đào Trung Kiên – ĐH Bách khoa Hà Nội