开发者

subscript operator on pointers

开发者 https://www.devze.com 2022-12-29 16:53 出处:网络
If I have a pointer to an ob开发者_Go百科ject that has an overloaded subscript operator ([]) why can\'t I do this:

If I have a pointer to an ob开发者_Go百科ject that has an overloaded subscript operator ([]) why can't I do this:

 MyClass *a = new MyClass();
 a[1];

but have to do this instead:

 MyClass *a = new MyClass();
 (*a)[1];


It's because you can't overload operators for a pointer type; you can only overload an operator where at least one of the parameters (operands) is of class type or enumeration type.

Thus, if you have a pointer to an object of some class type that overloads the subscript operator, you have to dereference that pointer in order to call its overloaded subscript operator.

In your example, a has type MyClass*; this is a pointer type, so the built-in operator[] for pointers is used. When you dereference the pointer and obtain a MyClass, you have a class-type object, so the overloaded operator[] is used.


Because a is type pointer to a MyClass and not a MyClass. Changing the language to support your desired use would make many other language semantics break.

You can get the syntactic result you want from:

struct foo {
    int a[10];
    int& operator [](int i) { return a[i]; }
};

main() {
    foo *a = new foo();
    foo &b = *a;
    b[2] = 3;
}


Good news. You can also do...

a->operator[](1);

To add on to the preferred answer, think of operator overloading as overloading functions.

When overloading member function of a class, you remember that the pointer is not of that class type.


Simply put, with a[1] the a pointer is treated as memory containing array, and you're trying to access the 2nd element in the array (which doesn't exist).

The (*a)[1] forces to first get the actual object at the pointer location, (*a), and then call the [] operator on it.

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号