1. Trang chủ
  2. » Giáo Dục - Đào Tạo

Bài giảng kỹ thuật lập trình – chương 8 lập trình phòng ngừa

38 1 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 38
Dung lượng 567,62 KB

Nội dung

co ng c om Trịnh Thành Trung (ThS) trungtt@soict.hust.edu.vn cu u du on g th a n Bài LẬP TRÌNH PHỊNG NGỪA CuuDuongThanCong.com https://fb.com/tailieudientucntt om c th a n co ng Nội dung cu u du on g Khái niệm Phịng ngừa sai sót liệu Xử lý lỗi Bảo đảm CuuDuongThanCong.com https://fb.com/tailieudientucntt om c ng co n th a Khái niệm cu u du on g Lập trình phịng ngừa CuuDuongThanCong.com https://fb.com/tailieudientucntt Lập trình phịng ngừa Defensive driving n th a du on g cu u = co ng c om Defensive Programming CuuDuongThanCong.com https://fb.com/tailieudientucntt om c Lập trình phịng ngừa Defensive programming du on g th a n co ng ▪ Ý tưởng chính: chương trình (CTC) nhận liệu vào bị lỗi chạy thơng, chương trình khác nhận liệu đầu vào bị lỗi ▪ Lập trình phịng ngừa cách tự bảo vệ chương trình khỏi cu u ▫ ảnh hưởng tiêu cực liệu không hợp lệ ▫ rủi ro đến từ kiện tưởng "không bao giờ" xảy ▫ sai lầm lập trình viên khác CuuDuongThanCong.com https://fb.com/tailieudientucntt ng ▪ Lỗi liên quan đến phần cứng c om Các lỗi phịng ngừa co ▫ Đảm bảo lỗi buffer overflows hay divide by zero kiểm soát th a n ▪ Lỗi liên quan đến chương trình du on g ▫ Đảm bảo giá trị gán cho biến ln nằm vùng kiểm sốt ▫ Do not trust anything; verify everything ▪ Lỗi liên quan đến người dùng u ▫ Đừng cho người dùng thực thao tác theo dẫn, kiểm tra thao tác họ cu ▪ Lỗi liên quan đến kỹ thuật phòng ngừa! ▫ Mã nguồn cài đặt kỹ thuật phòng ngừa có khả gây lỗi, kiểm tra kỹ phần CuuDuongThanCong.com https://fb.com/tailieudientucntt .c ng ▪ Lập kế hoạch thực cơng việc: om Các giai đoạn lập trình phịng ngừa th a ▪ Thiết kế chương trình: n co ▫ Dành thời gian để kiểm tra gỡ rối chương trình cẩn thận : hồn thành chương trình trước ngày so với hạn nộp ▫ Thiết kế giải thuật trước viết ngôn ngữ lập trình cụ thể du on g ▪ Giữ vững cấu trúc chương trình: cu u ▫ Viết kiểm thử phần chương trình: phần chương trình dùng để làm ▫ Viết kiểm thử mối liên kết phần chương trình: quy trình nghiệp vụ ▫ Phòng ngừa điều kiện trước sau gọi phần chương trình: điều phải trước gọi chương trình, điều xảy sau chương trình thực xong ▫ Dùng thích để miêu tả cấu trúc chương trình viết chương trình CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Kiểm tra gì, nào? n co ng ▪ Testing: vấn đề làm chương trình khơng chạy ▪ Kiểm tra theo cấu trúc chương trình: Kiểm tra việc thực nhiệm vụ đặt cho phần chương trình du on g th a ▫ Ví dụ: điều xảy với chương trình lề văn bản, hàm ReadWord() bị lỗi ? u ▪ Nếu chương trình khơng có tham số đầu vào, mà thực thi nhiệm vụ sinh kết khơng cần kiểm tra nhiều Hầu hết chương trình khơng cu ▫ Ví dụ: điều xảy với chương trình lề văn bản, ▸ Không nhập đầu vào ? ▸ Đầu vào xâu/file chứa từ hay chữ quy định ? CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Kiểm soát lỗi xảy co ng ▪ Error handling: xử lý lỗi mà ta dự kiến xảy ▪ Tùy theo tình cụ thể, ta trả về: cu u du on g th a n ▫ giá trị trung lập ▫ thay đoạn liệu hợp lệ ▫ trả giá trị lần trước ▫ thay giá trị hợp lệ gần ▫ ghi vết cảnh báo vào tệp ▫ trả mã lỗi ▫ gọi thủ tục hay đối tượng xử lý ▫ thông báo hay tắt máy CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Chắc chắn hay xác? du on g th a n co ng ▪ Chắc chắn: chương trình ln chạy thơng, kể có lỗi ▪ Chính xác: chương trình khơng gặp lại lỗi ▪ Ví dụ: Lỗi thị trình xử lý văn bản: thay đổi nội dung văn bản, phần dịng văn phía hình bị thị sai Khi người dùng phải làm gì? u ▫ Tắt chương trình ▫ Nhấn PgUp PgDn, hình làm cu Ưu tiên tính chắn thay tính xác: ▫ Bất kết thường tốt so với Shutdown CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Kiểm tra để phát lỗi ng ▪ Kiểm tra thao tác gây lỗi viết chương trình n th a ▪ Ví dụ: co ▫ Nhập liệu ▫ Sử dụng liệu cu u du on g ▫ Kiểm tra lần mở tệp tin hay cấp phát ô nhớ ▫ Kiểm tra phương thức người dùng nhập liệu vào khơng cịn nguy gây dừng chương trình ▫ Trong trường hợp tràn nhớ (out of memory), nên in lỗi kết thúc chương trình (-1: error exit); ▫ Trong trường hợp liệu người dùng đưa vào bị lỗi, tạo hội cho người dùng nhập lại liệu (lỗi tên file người dùng nhập sai) CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Kiểm sốt lỗi xảy co ng ▪ Error handling: xử lý lỗi mà ta dự kiến xảy ▪ Tùy theo tình cụ thể, ta trả về: cu u du on g th a n ▫ giá trị trung lập ▫ thay đoạn liệu hợp lệ ▫ trả giá trị lần trước ▫ thay giá trị hợp lệ gần ▫ ghi vết cảnh báo vào tệp ▫ trả mã lỗi ▫ gọi thủ tục hay đối tượng xử lý ▫ thông báo hay tắt máy CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Bắt ngoại lệ cu u du on g th a n co ng ▪ Exception: bắt tình bất thường phục hồi chúng trạng thái trước ▪ Giú p chương trình đáng tin cậy hơn, trá nh kết thúc bất thường ▪ Tá ch biẹ t khó i lẹ nh có thẻ gây ngoạ i lẹ và khó i lẹ nh xử lý ………… ngoạ i lẹ IF B IS ZERO GO TO ERROR C = A/B PRINT C GO TO EXIT ERROR: DISPLAY “DIVISION BY ZERO” Khối xử lý lỗi EXIT: END CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Ví dụ Bắt ngoại lệ co cmd.ExecuteNonQuery(); ErrorsManager.SetError(ErrorIDs.KhongCoLoi); n try { ng ▪ C# Try u ▪ VB.NET du on g th a } catch { ErrorsManager.SetError(ErrorIDs.SQLThatBai, database.DbName,“ten_strore"); } cu Return CBO.FillCollection(CType(SqlHelper.ExecuteReader(ConStr, "TimHDon", iSoHoaDon), IDataReader),GetType(ThanhToan.ChiTietHDInfo)) Catch ex As Exception mesagebox.show(ex.message) End Try CuuDuongThanCong.com https://fb.com/tailieudientucntt ng ▪ Phục hồi tài nguyên xảy lỗi? c om Phục hồi tài nguyên cu u du on g th a n co ▫ Thường khơng phục hồi tài ngun, hữu ích thực công việc nhằm đảm bảo cho thông tin trạng thái rõ ràng vô hại ▫ Nếu biến cịn truy xuất chúng nên gán giá trị hợp lý ▫ Trường hợp thực thi việc cập nhật liệu, phiên – transaction – liên quan tới nhiều bảng chính, phụ, việc khơi phục có ngoại lệ vơ cần thiết (rollback ) CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Chắc chắn hay xác? du on g th a n co ng ▪ Chắc chắn: chương trình ln chạy thơng, kể có lỗi ▪ Chính xác: chương trình khơng gặp lại lỗi ▪ Ví dụ: Lỗi thị trình xử lý văn bản: thay đổi nội dung văn bản, phần dòng văn phía hình bị thị sai Khi người dùng phải làm gì? u ▫ Tắt chương trình ▫ Nhấn PgUp PgDn, hình làm cu Ưu tiên tính chắn thay tính xác: ▫ Bất kết thường tốt so với Shutdown CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Khi phải loại bỏ hết lỗi ng ▪ Đôi khi, để loại bỏ lỗi nhỏ, lại tốn du on g th a n co ▫ Nếu lỗi chắn khơng ảnh hưởng đến mục đích ứng dụng, khơng làm chương trình bị treo, làm sai lệch kết chính, người ta bỏ qua, mà khơng cố sửa để gặp phải nguy khác cu u ▪ Phần mềm “chịu lỗi”?: Phần mềm sống chung với lỗi, để đảm bảo tính liên tục, ổn định CuuDuongThanCong.com https://fb.com/tailieudientucntt om c ng co n th a cu u Assertion du on g Bảo đảm CuuDuongThanCong.com https://fb.com/tailieudientucntt .c om Bảo đảm Assertions du on g th a n co ng ▪ Assertion: macro hay chương trình dùng trình phát triển ứng dụng, cho phép chương trình tự kiểm tra chạy ▪ Return true >> OK, false >> có lỗi chương trình ▪ Ghi lại giả thiết đưa code ▪ Loại bỏ điều kiện khơng mong đợi Ví dụ cu u ▫ Nếu hệ thống cho file liệu khách hàng không vượt 50 000 ghi, chương trình chứa assertion số ghi

Ngày đăng: 28/12/2021, 19:12