Nạp chồng toán tử truy cập thành viên lớp (->) trong C++



Toán tử truy cập thành viên lớp (->) có thể được nạp chồng, nhưng nó khá là phức tạp. Nó được định nghĩa để cung cấp một kiểu lớp một hành vi "pointer-like". Toán tử -> phải là một hàm thành viên. Nếu được sử dụng, kiểu trả về của nó phải là một con trỏ hoặc một đối tượng của một lớp để bạn có thể áp dụng.

Toán tử -> thường được sử dụng kết hợp với toán tử * để triển khai "smart pointer". Những con trỏ này là các đối tượng mà vận hành như các con trỏ thông thường, ngoại trừ việc chúng thực hiện các tác vụ khi bạn truy cập một đối tượng thông qua chúng, ví dụ: xóa đối tượng tự động hoặc khi con trỏ bị hủy hoặc khi con trỏ được sử dụng để trỏ tới đối tượng khác.

Toán tử -> có thể được định nghĩa như là một toán tử hậu tố một ngôi.

class Ptr{
   //...
   X * operator->();
};

Các đối tượng của lớp Ptr có thể được sử dụng để truy cập các thành viên của lớp X ở trên theo phương thức giống như cách các con trỏ được sử dụng. Ví dụ:

void f(Ptr p )
{
   p->m = 10 ; // la tuong tu (p.operator->())->m = 10
}

Lệnh p->m được thông dịch thành (p.operator->())->m. Sử dụng cùng khái niệm trên, ví dụ sau sẽ giải thích cách một toán tử truy cập lớp -> trong C++ có thể được nạp chồng.

#include <iostream>
#include <vector>
using namespace std;

// gia su co mot lop VietJack sau.
class VietJack {
   static int i, j;
public:
   // cac smart pointer de hien thi
   void f() const { cout << i++ << endl; }
   void g() const { cout << j++ << endl; }
   void h() const { cout << "--------" << endl; }
};

// phan dinh nghia cac thanh vien Static:
int VietJack::i = 4;
int VietJack::j = 15;

// Trien khai mot container cho lop tren
class VJContainer {
   vector<VietJack*> a;
public:
   void add(VietJack* vj)
   { 
      a.push_back(vj);  // goi phuong thuc chuan cua vector.
   }
   friend class SmartPointer;
};

// trien khai smart pointer de truy cap thanh vien cua lop VietJack.
class SmartPointer {
   VJContainer vc;
   int index;
public:
   SmartPointer(VJContainer& vjc)
   { 
       vc = vjc;
       index = 0;
   }
   // tra ve gia tri de chi phan cuoi cua danh sach:
   bool operator++() // phien ban toan tu ++ (tien to)
   { 
     if(index >= vc.a.size()) return false;
     if(vc.a[++index] == 0) return false;
     return true;
   }
   bool operator++(int) // phien ban toan tu ++ (hau to)
   { 
      return operator++();
   }
   // nap chong operator->
   VietJack* operator->() const 
   {
     if(!vc.a[index])
     {
        cout << "Gia tri 0!!";
        return (VietJack*)0;
     }
     return vc.a[index];
   }
};

int main() {
   const int sz = 5; // so vong lap la 5 (ban thiet lap gia tri khac de xem ket qua)
   VietJack o[sz];
   VJContainer vc;
   for(int i = 0; i < sz; i++)
   {
       vc.add(&o[i]);
   }
   SmartPointer sp(vc); // tao mot iterator
   do {
      sp->f(); // goi smart pointer
      sp->g();
      sp->h();
   } while(sp++);
   return 0;
}

Biên dịch và chạy chương trình C++ trên sẽ cho kết quả sau:

Nạp chồng toán tử truy cập thành viên lớp trong C++

Đã có app VietJack trên điện thoại, giải bài tập SGK, SBT Soạn văn, Văn mẫu, Thi online, Bài giảng....miễn phí. Tải ngay ứng dụng trên Android và iOS.

Theo dõi chúng tôi miễn phí trên mạng xã hội facebook và youtube:

Các bạn có thể mua thêm khóa học JAVA CORE ONLINE VÀ ỨNG DỤNG cực hay, giúp các bạn vượt qua các dự án trên trường và đi thực tập Java. Khóa học có giá chỉ 300K, nhằm ưu đãi, tạo điều kiện cho sinh viên cho thể mua khóa học.

Nội dung khóa học gồm 16 chuơng và 100 video cực hay, học trực tiếp tại https://www.udemy.com/tu-tin-di-lam-voi-kien-thuc-ve-java-core-toan-tap/ Bạn nào có nhu cầu mua, inbox trực tiếp a Tuyền, cựu sinh viên Bách Khoa K53, fb: https://www.facebook.com/tuyen.vietjack

Follow facebook cá nhân Nguyễn Thanh Tuyền https://www.facebook.com/tuyen.vietjack để tiếp tục theo dõi các loạt bài mới nhất về Java,C,C++,Javascript,HTML,Python,Database,Mobile.... mới nhất của chúng tôi.


nap_chong_ham_va_nap_chong_toan_tu_trong_cplusplus.jsp


Tài liệu giáo viên