Bài giảng Kỹ thuật lập trình – Chương 4: Kỹ thuật viết mã nguồn hiệu quả
lượt xem 6
download
Bài giảng Kỹ thuật lập trình – Chương 4: Kỹ thuật viết mã nguồn hiệu quả. Những nội dung chính được trình bày trong chương này gồm có: Các kỹ thuật viết mã nguồn hiệu quả, những nguyên tắc cơ bản trong việc tăng hiệu quả viết mã nguồn, tối ưu hóa mã nguồn C/C++.
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: Bài giảng Kỹ thuật lập trình – Chương 4: Kỹ thuật viết mã nguồn hiệu quả
- Chương 4: om .c Kỹ thuật viết mã nguồn ng co hiệu quả an th o ng du u cu 3/24/2020 1 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Nội dung 1. Các kỹ thuật viết mã nguồn hiệu quả om 2. Những nguyên tắc cơ bản trong việc .c tăng hiệu quả viết mã nguồn ng co 3. Tối ưu hóa mã nguồn C/C++ an th o ng du u cu 3/24/2020 2 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Chương trình hiệu quả • Trước hết là giải thuật • Hãy dùng giải thuật hay nhất có thể om • Sau đó hãy nghĩ tới việc tăng tính hiệu quả của code .c • Ví dụ: Tính tổng của n số tự nhiên liên tiếp kể từ m ng co void main(){ void main(){ an long n, m, i, sum; long n, m, sum; th cin
- Dùng chỉ thị chương trình dịch • Một số compilers có vai trò rất lớn trong việc tối ưu chương trình om .c • Chúng phân tích sâu mã nguồn và làm mọi điều “machinely” có thể ng co • Ví dụ GNU g++ compiler trên Linux/Cygwin cho chương trình viết bằng C an th g++ –O5 –o myprog myprog.c ng • Có thể cải thiện hiệu năng từ 10% đến 300% o du u cu 3/24/2020 4 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Nhưng... • Bạn vẫn có thể thực hiện những cải tiến mà trình dịch không thể om • Bạn phải loại bỏ tất cả những chỗ bất hợp lý trong .c code ng • Làm cho chương trình hiệu quả nhất có thể co • Có thể phải xem lại khi thấy chương trình chạy chậm an th • Vậy cần tập trung vào đâu để cải tiến nhanh nhất, tốt nhất? ng o du u cu 3/24/2020 5 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Viết chương trình hiệu quả • Xác định nguồn gây kém hiệu quả • Dư thừa tính toán - redundant computation om • Chủ yếu .c • Trong các procedure ng • Các vòng lặp: Loops co an th o ng du u cu 3/24/2020 6 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Khởi tạo 1 lần, dùng nhiều lần • Before float f(){ om double value = sin(0.25); // .c … ng } co an • After th ng double defaultValue = sin(0.25); o float f(){ du double value = defaultValue; u // cu … } 3/24/2020 7 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Hàm nội tuyến (inline functions) Điều gì xảy ra khi một hàm được gọi? om CPU sẽ lưu địa chỉ bộ nhớ của dòng lệnh hiện tại mà nó đang thực thi (để biết nơi sẽ quay lại sau lời gọi .c hàm), sao chép các đối số của hàm trên ngăn xếp ng (stack) và cuối cùng chuyển hướng điều khiển sang co hàm đã chỉ định. CPU sau đó thực thi mã bên trong an hàm, lưu trữ giá trị trả về của hàm trong một vùng th nhớ/thanh ghi và trả lại quyền điều khiển cho vị trí lời gọi ng hàm o du ➔ Điều này sẽ tạo ra một lượng chi phí hoạt động nhất u định (overhead) so với việc thực thi mã trực tiếp (không cu sử dụng hàm). 3/24/2020 8 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Hàm nội tuyến (inline functions) • Đối với các hàm lớn hoặc các tác vụ phức tạp, tổng chi phí overhead của lệnh gọi hàm thường không đáng om kể so với lượng thời gian mà hàm mất để chạy. .c • Tuy nhiên, đối với các hàm nhỏ, thường xuyên được ng sử dụng, thời gian cần thiết để thực hiện lệnh gọi hàm co thường nhiều hơn rất nhiều so với thời gian cần thiết an để thực thi mã của hàm. th • Inline functions (hàm nội tuyến) là một loại hàm ng trong ngôn ngữ lập trình C++. Từ khoá inline được sử o du dụng để đề nghị (không phải là bắt buộc) compiler u (trình biên dịch) thực hiện inline expansion (khai cu triển nội tuyến) với hàm đó hay nói cách khác là chèn code của hàm đó tại địa chỉ mà nó được gọi. 3/24/2020 9 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Hàm nội tuyến (inline functions) • Đối với các hàm lớn hoặc các tác vụ phức tạp, tổng chi phí overhead của lệnh gọi hàm thường không đáng om kể so với lượng thời gian mà hàm mất để chạy. .c • Tuy nhiên, đối với các hàm nhỏ, thường xuyên được ng sử dụng, thời gian cần thiết để thực hiện lệnh gọi hàm co thường nhiều hơn rất nhiều so với thời gian cần thiết an để thực thi mã của hàm. th • Inline functions (hàm nội tuyến) là một loại hàm ng trong ngôn ngữ lập trình C++. Từ khoá inline được sử o du dụng để đề nghị (không phải là bắt buộc) compiler u (trình biên dịch) thực hiện inline expansion (khai cu triển nội tuyến) với hàm đó hay nói cách khác là chèn code của hàm đó tại địa chỉ mà nó được gọi. 3/24/2020 10 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Inline functions #include #include om using namespace std; .c inline double hypothenuse (double a, double b){ ng return sqrt (a * a + b * b); co } an int main (){ double k = 6, m = 9; th ng // 2 dòng sau thực hiện như nhau: o du cout
- Inline functions #include using namespace std; om inline int max(int a, int b){ return a > b ? a : b; .c } ng int main() { co cout
- Inline functions #include using namespace std; om inline int max(int a, int b){ return a > b ? a : b; .c } ng int main() { co cout
- Inline functions Trình biên dịch có thể không thực hiện nội tuyến trong các trường hợp như: om • Hàm chứa vòng lặp (for, while, do-while). .c • Hàm chứa các biến tĩnh. ng • Hàm đệ quy. co an • Hàm chứa câu lệnh switch hoặc goto. th o ng du u cu 3/24/2020 14 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Inline functions • Ưu điểm: ‒ Tiết kiệm chi phí gọi hàm. om ‒ Tiết kiệm chi phí của các biến trên ngăn xếp khi hàm được .c gọi. ng ‒ Tiết kiệm chi phí cuộc gọi trả về từ một hàm. co • Nhược điểm: an ‒ Tăng kích thước file thực thi do sự trùng lặp của cùng một th ng mã. o ‒ Khi được sử dụng trong file tiêu đề (*.h), nó làm cho file tiêu du đề của bạn lớn hơn. u cu ‒ Hàm nội tuyến có thể không hữu ích cho nhiều hệ thống nhúng. Vì trong các hệ thống nhúng, kích thước mã quan trọng hơn tốc độ. 3/24/2020 15 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Macros #define max(a,b) (a > b ? a : b) • Các hàm inline cũng giống như macros vì cả 2 được om khai triển khi dịch compile time .c • macros được khai triển bởi preprocessor, còn inline ng functions được truyền bởi compiler. co • Tuy nhiên có nhiều điểm khác biệt: an • Inline functions tuân thủ các thủ tục như 1 hàm binh th thường. ng • Inline functions có cùng syntax như các hàm khác, chỉ o có điều là có thêm từ khóa inline khi khai báo hàm. du • Các biểu thức truyền như là đối số cho inline functions u được tính 1 lần. Biểu thức truyền như tham số cho cu macros có thể được tính mỗi lần macro được sử dụng. • Bạn không thể gỡ rối cho macros, nhưng với inline functions thì có thể. 3/24/2020 16 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Biến tĩnh (static variables) • Kiểu dữ liệu static tham chiếu tới global hay 'static' variables, chúng được cấp phát bộ nhớ khi dịch om compile-time. .c ng int int_array[100]; co int main() { an static float float_array[100]; th double double_array[100]; ng char *pchar; o pchar = (char *)malloc(100); du /* .... */ u cu return (0); } 3/24/2020 17 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Static Variables • Các biến khai báo trong chương trình con được cấp phát bộ nhớ khi chương trình con được gọi và sẽ bị loại bỏ khi kết om thúc chương trình con. .c • Khi bạn gọi lại chương trình con, các biến cục bộ lại được ng cấp phát và khởi tạo lại. co • Nếu bạn muốn 1 giá trị vẫn được lưu lại cho đến khi kết an thúc toàn chương trình, bạn cần khai báo biến cục bộ của th chương trình con đó là static và khởi tạo cho nó 1 giá trị. ng • Việc khởi tạo sẽ chỉ thực hiện lần đàu tiên chương trình được o gọi và giá trị sau khi biến đổi sẽ được lưu cho các lần gọi sau. du • Bằng cách này 1 chương trình con có thể “nhớ” một vài mẩu u tin sau mỗi lần được gọi. cu • Dùng biến Static thay vì Global: • Ưu điểm của 1 biến static: biến cục bộ của chương trình con, do đó tránh được các hiệu ứng phụ (side effects). 3/24/2020 18 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Stack, heap • Khi thực hiện, vùng dữ liệu data segment của một chương trình được chia làm 3 phần: om • static, stack, và heap data. .c • Static: global hay static variables ng co • Stack data: an • các biến cục bộ của chương trình con th • ví dụ double_array trong ví dụ trên. ng • Heap data: o du • Dữ liệu được cấp phát động (ví dụ, pchar trong ví u dụ trên). cu • Dữ liệu này sẽ còn cho đến khi ta giải phóng hoặc khi kết thúc chương trình. 3/24/2020 19 CuuDuongThanCong.com https://fb.com/tailieudientucntt
- Tính toán trước các giá trị • Nếu bạn phải tính đi tính lại 1 biểu thức, thì nên tính trước 1 lần và lưu lại giá trị, rồi dùng om giá trị ấy sau này .c ng int f(int i){ static int[] values = co if (i < 10 && i >= 0){ {0, 0, 2,3*3-3, ..., 9*9-9}; return i * i - i; int f(int i){ an } if (i < 10 && i >= 0) th return 0; return values[i]; ng } o return 0; du } u cu 3/24/2020 20 CuuDuongThanCong.com https://fb.com/tailieudientucntt
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Kỹ thuật lập trình: Chương 1 - Trần Quang
39 p | 11 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 8 - Trần Quang
34 p | 9 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 7 - Trần Quang
28 p | 10 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 6 - Trần Quang
37 p | 13 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 4 - Trần Quang
32 p | 8 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 3 - Trần Quang
52 p | 11 | 2
-
Bài giảng Kỹ thuật lập trình: Chương 2 - Trần Quang
25 p | 12 | 2
-
Bài giảng Kỹ thuật lập trình: Hàm nâng cao (Phần 1) - ThS. Đặng Bình Phương
26 p | 0 | 0
-
Bài giảng Kỹ thuật lập trình: Các kỹ thuật thao tác trên bit - ThS. Đặng Bình Phương
29 p | 3 | 0
-
Bài giảng Kỹ thuật lập trình: Tập tin - ThS. Đặng Bình Phương
48 p | 3 | 0
-
Bài giảng Kỹ thuật lập trình: Kỹ thuật lập trình đệ quy - ThS. Đặng Bình Phương
44 p | 3 | 0
-
Bài giảng Kỹ thuật lập trình: Dữ liệu kiểu cấu trúc - ThS. Đặng Bình Phương
33 p | 2 | 0
-
Bài giảng Kỹ thuật lập trình: Chuỗi ký tự - ThS. Đặng Bình Phương
20 p | 4 | 0
-
Bài giảng Kỹ thuật lập trình: Danh sách liên kết - ThS. Đặng Bình Phương
20 p | 3 | 0
-
Bài giảng Kỹ thuật lập trình: Chuyển đổi kiểu dữ liệu và cấp phát bộ nhớ động - ThS. Đặng Bình Phương
28 p | 4 | 0
-
Bài giảng Kỹ thuật lập trình: Dữ liệu kiểu con trỏ (Nâng cao) - ThS. Đặng Bình Phương
48 p | 1 | 0
-
Bài giảng Kỹ thuật lập trình: Giới thiệu môn học - ThS. Đặng Bình Phương
7 p | 2 | 0
-
Bài giảng Kỹ thuật lập trình: Hàm nâng cao (Phần 2) - ThS. Đặng Bình Phương
30 p | 0 | 0
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