Bài giảng Lập trình hướng đối tượng C++ - Chương 8: Tái định nghĩa (Overloading)
Bạn đang xem tài liệu "Bài giảng Lập trình hướng đối tượng C++ - Chương 8: Tái định nghĩa (Overloading)", để 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:
- bai_giang_lap_trinh_huong_doi_tuong_c_chuong_8_tai_dinh_nghi.ppt
Nội dung text: Bài giảng Lập trình hướng đối tượng C++ - Chương 8: Tái định nghĩa (Overloading)
- CHƯƠNG 8: TÁI ĐỊNH NGHĨA (OVERLOADING) Bộ môn Hệ Thống Máy Tính và Truyền Thông Khoa Công Nghệ Thông Tin và Truyền Thông Đại học Cần Thơ Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 1
- Chương 8 Nội dung n Tái định nghĩa hàm. n Tái định nghĩa toán tử. n Chuyển đổi kiểu. n Tái định nghĩa toán tử xuất ( >) n Tái định nghĩa toán tử [], toán tử () n Khởi tạo ngầm định - Gán ngầm định. n Tái định nghĩa toán tử ++ và n Tái định nghĩa new và delete Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 2
- Chương 8 Tái định nghĩa hàm n Định nghĩa các hàm cùng tên n Đối số phải khác nhau: ¨ Số lượng ¨ Kiểu ¨ Thứ tự class Time { void main() { // int h, m, s; long GetTime (void); // số giây tính từ nửa đêm long t = GetTime(); // Gọi hàm ??? void GetTime (int &hours, GetTime(h, m, s); // Gọi hàm ??? int &minutes, } int &seconds); }; n Có thể dùng đối số mặc định. Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 3
- Chương 8 Tái định nghĩa toán tử n Định nghĩa các phép toán trên đối tượng. n Các phép toán có thể tái định nghĩa: + - * ! ~ & ++ () -> ->* Đơn hạng new delete + - * / % & | ^ > Nhị = += -= /= %= &= |= ^= >= hạng == != = && || [] () , n Các phép toán không thể tái định nghĩa: . .* :: ?: sizeof Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 4
- Chương 8 Tái định nghĩa toán tử (tt) n Bằng hàm thành viên: class Point { public: Point (int x, int y) { Point::x = x; Point::y = y; } Point operator + (Point &p) { return Point(x + p.x,y + p.y); } Point operator - (Point &p) { return Point(x - p.x, y - p.y); } private: int x, y; }; Có 1 tham số (Nếu là toán tử nhị hạng) void main() { Point p1(10,20), p2(10,20); Point p3 = p1 + p2; Point p4 = p1 - p2; Point p5 = p3.operator + (p4); Point p6 = p3.operator – (p4); }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 5
- Chương 8 Tái định nghĩa toán tử (tt) n Bằng hàm độc lập: thường khai báo friend class Point { public: Point (int x, int y) { Point::x = x; Point::y = y; } friend Point operator + (Point &p, Point &q) {return Point(p.x + q.x,p.y + q.y); } friend Point operator - (Point &p, Point &q) {return Point(p.x - q.x,p.y - q.y); } private: Có 2 tham số int x, y; (Nếu là toán tử nhị hạng) }; void main() { Point p1(10,20), p2(10,20); Point p3 = p1 + p2; Point p4 = p1 - p2; Point p5 =operator + (p3, p4); Point p6 = operator – (p3, p4); }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 6
- Chương 8 Tái định nghĩa toán tử (tt) n Cải tiến lớp tập hợp (Set): #include // Định nghĩa các toán tử const maxCard = 100; . enum Bool {false, true}; . class Set { int main (void) public: { Set s1, s2, s3; Set(void) { card = 0; } s1.AddElem(10); s1.AddElem(20); friend Bool operator & (const int, Set&);// thanh vien ? s1.AddElem(30); s1.AddElem(40); friend Bool operator == (Set&, Set&); // bang ? s2.AddElem(30); s2.AddElem(50); friend Bool operator != (Set&, Set&); // khong bang ? s2.AddElem(10); s2.AddElem(60); friend Set operator * (Set&, Set&); // giao cout << "s1 = "; s1.Print(); friend Set operator + (Set&, Set&); // hop // cout << "s2 = "; s2.Print(); void AddElem(const int elem); if (20 & s1) cout << "20 thuoc s1\n"; void Copy (Set &set); cout << "s1 giao s2 = "; (s1 * s2).Print(); void Print (void); cout << "s1 hop s2 = "; (s1 + s2).Print(); private: if (s1 != s2) cout << "s1 /= s2\n"; int elems[maxCard]; int card; return 0; }; } Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 7
- Chương 8 Chuyển kiểu n Muốn thực hiện các phép cộng: void main() { Point p1(10,20), p2(30,40), p3, p4, p5; p3 = p1 + p2; p4 = p1 + 5; p5 = 5 + p1; }; Có thể định nghĩa thêm 2 toán tử: class Point { // friend Point operator + (Point, Point); friend Point operator + (int, Point); friend Point operator + (Point, int); }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 8
- Chương 8 Chuyển kiểu (tt) n Chuyển đổi kiểu: ngôn ngữ định nghĩa sẵn. void main() { Point p1(10,20), p2(30,40), p3, p4, p5; p3 = p1 + p2; p4 = p1 + 5; // tương đương p1 + Point(5) p5 = 5 + p1; // tương đương Point(5) + p1 } Định nghĩa phép chuyển đổi kiểu class Point { // Chuyển kiểu Point (int x) { Point::x = Point::y = x; } 5 Point(5) friend Point operator + (Point, Point); }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 9
- Chương 8 Tái định nghĩa toán tử xuất << n Định nghĩa hàm toàn cục: ostream& operator << (ostream&, Class&); class Point { void main() { public: Point p1(10,20), p2; Point (int x=0, int y=0) cout<<“Diem P1: “<< p1 << endl; { Point::x = x; Point::y = y; } cout<<“Diem P2: “<< p2 << endl; friend ostream& operator << } (ostream& os, Point& p) { os<< “(“ << p.x << “,” << p.y << “)”; } // private: Kết quả int x, y; trên }; màn hình ? Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 10
- Chương 8 Tái định nghĩa toán tử nhập >> n Định nghĩa hàm toàn cục: istream& operator >> (istream&, Class&); class Point { void main() { public: Point p1, p2; Point (int x=0, int y=0) cout >p1; friend istream& operator >> cout >p2; { cout >p.x; } cout >p.y; } // private: int x, y; }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 11
- Chương 8 Tái định nghĩa toán tử [ ] n Thông thường để xuất ra giá trị của 1 phần tử tại vị trí cho trước trong đối tượng. n Định nghĩa là hàm thành viên. class StringVec { char* StringVec::operator [] (int i) { public: if ( i>=0 && i<used) return elems[i]; StringVec (const int dim); return “”; ~StringVec (); } char* operator [] (int); int add(char* ); void main() { // StringVec sv1(100); private: sv1.add(“PTPhi”);sv1.add(“BQThai”); char elems; // cac phan tu sv1.add(“LVLam”); sv1.add(“NCHuy”); int dim; // kich thuoc cua vecto cout<< sv1[2]<<endl; int used; // vi tri hien tai cout<<sv1[0]; }; } Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 12
- Chương 8 Tái định nghĩa toán tử () n Định nghĩa là hàm thành viên. class Matrix { double& Matrix::operator () public: (const short row, const short col) Matrix (const short rows, const short cols); { ~Matrix (void) {delete elems;} static double dummy = 0.0; double& operator () (const short row, return (row >= 1 && row = 1 && col <= cols) ? elems[(row - 1)*cols friend ostream& operator << (ostream&, Matrix&); + (col - 1)] friend Matrix operator + (Matrix&, Matrix&); : dummy; friend Matrix operator - (Matrix&, Matrix&); } friend Matrix operator * (Matrix&, Matrix&); void main() { private: Matrix m(3,2); const short rows; // số hàng m(1,1) = 10; m(1,2) = 20; const short cols; // số cột m(2,1) = 30; m(2,2) = 40; double *elems; // các phần tử m(3,1) = 50; m(3,2) = 60; }; cout<<m<<endl; } Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 13
- Chương 8 Khởi tạo ngầm định n Được định nghĩa sẵn trong ngôn ngữ: VD: Point p1(10,20); Point p2 = p1; n Sẽ gây ra lỗi (kết quả SAI) khi bên trong đối tượng có thànhthành phầnphần dữdữ liệuliệu làlà concon trỏtrỏ. VD: Matrix m(5,6); Matrix n = m; Lỗi sẽ xảy ra do khởi tạo ngầm bằng cách gán tương ứng từng thành phần. Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 14
- Chương 8 Khởi tạo ngầm định (tt) Khi lớp có thànhthành phầnphần dữdữ liệuliệu concon trỏtrỏ, phải định nghĩa hàm xâyxây dựngdựng saosao chépchép class Point { class Matrix { int x, y; // . public: Matrix(const Matrix&); Point (int =0; int =0 ); }; // Khong can thiet DN Matrix::Matrix (const Matrix &m) Point (const Point& p) { : rows(m.rows), cols(m.cols) x= p.x; { y = p.y; int n = rows * cols; } elems = new double[n]; // cùng kích thước // for (register i = 0; i < n; ++i) // sao chép phần tử }; elems[i] = m.elems[i]; // } Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 15
- Chương 8 Gán ngầm định n Được định nghĩa sẵn trong ngôn ngữ: ¨ Gán tương ứng từng thành phần. ¨ Đúng khi đối tượng không có dữ liệu con trỏ. VD: Point p1(10,20); Point p2; p2 = p1; n Khi thành phần dữ liệu có con trỏ, bắt buộc phải định nghĩa phép gán = cho lớp. class Matrix { // . Hàm Matrix& operator = (const Matrix &m) { thành if (rows == m.rows && cols == m.cols) { // phải khớp viên int n = rows * cols; for (register i = 0; i < n; ++i) // sao chép các phần tử elems[i] = m.elems[i]; } return *this; } }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 16
- Chương 8 Tái định nghĩa toán tử ++ & n Toán tử ++ (hoặc toán tử ) có 2 loại: ¨ Tiền tố: ++n ¨ Hậu tố: n++ class PhanSo { void main() { int tuso, mau so; PhanSo p1(3,4), p2; public: cout<< p1++; // PhanSo(int=0 , int =1); cout<<++p2; friend PhanSo operator ++ (PhanSo&); cout<<++(p1++) + (++p2)++; friend PhanSo operator ++ (PhanSo&, int); } }; PhanSo operator ++ (PhanSo& p) { return (p = PhanSo(tuso+mauso, mauso)); } PhanSo operator ++ (PhanSo& p, int x) { Kết quả trên PhanSo p2 = PhanSo(tuso+mauso, mauso); màn hình ? return p2; } Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 17
- Chương 8 Tái định nghĩa new & delete n Hàm new và delete mặc định của ngôn ngữ: ¨ Nếu đối tượng kích thước nhỏ, có thể sẽ gây ra quá nhiều khối nhỏ => chậm. ¨ Không đáng kể khi đối tượng có kích thước lớn. => Toán tử new và delete ít được tái định nghĩa. n Định nghĩa theo dạng hàm thành viên: class Point { void main() { public: Point *p = new Point(10,20); // Point *ds = new Point[30]; void* operator new (size_t bytes); // void operator delete (void *ptr, size_t bytes); delete p; private: delete []ds; int xVal, yVal; } }; Khoa Công Nghệ Thông Tin - Đại Học Cần Thơ 18