2차원 배열에 대한 [] 연산자 오버로드
연산자 오버로드를 통해 프로그래머는 기존 연산자의 기능을 확장하여 사용자 정의 동작을 생성할 수 있습니다. 그들의 클래스와 객체. 일반적인 사용 사례 중 하나는 배열 요소에 액세스하기 위해 [] 연산자를 오버로드하는 것입니다. 그런데 [] 연산자를 두 번 오버로드하여 효과적으로 2차원 배열을 생성하는 것이 가능할까요?
[] 연산자의 이중 오버로딩
예, 가능합니다. 2차원 배열 동작을 달성하기 위해 [] 연산자를 여러 번 오버로드합니다. 자체적으로 [ ] 인덱싱을 처리할 수 있는 객체를 반환하도록 하나의 [ ] 연산자를 정의하면 중첩 배열과 유사한 구조를 생성할 수 있습니다.
예제 코드
다음 코드 샘플:
class ArrayOfArrays { public: ArrayOfArrays() { _arrayofarrays = new int*[10]; for(int i = 0; i < 10; ++i) _arrayofarrays[i] = new int[10]; } class Proxy { public: Proxy(int* _array) : _array(_array) { } int operator[](int index) { return _array[index]; } private: int* _array; }; Proxy operator[](int index) { return Proxy(_arrayofarrays[index]); } private: int** _arrayofarrays; };
이 코드에서 ArrayOfArrays 클래스는 2차원 배열을 나타냅니다. [ ] 연산자는 두 번 오버로드됩니다.
사용법
ArrayOfArrays 클래스를 사용하려면 일반 2차원 배열인 것처럼 두 번 인덱싱할 수 있습니다.
ArrayOfArrays aoa; aoa[3][5]; // Access the element at row 3, column 5
이 코드는 먼저 ArrayOfArrays 인스턴스에서 [ ] 연산자를 호출하여 프록시 객체를 반환합니다. 그런 다음 프록시 객체에서 [ ] 연산자를 호출하여 행 3의 열 5에 있는 요소를 반환합니다.
[ ] 연산자의 이중 오버로드를 구현하면 2차원 배열의 동작을 분석하고 더 복잡한 데이터 저장 및 검색 시나리오를 위한 중첩 구조를 만듭니다.
위 내용은 C에서 2차원 배열을 생성하기 위해 [] 연산자를 두 번 오버로드할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!