指针运算符重载为什么operator前面没有返回值,而且为什么是T*而不是*

operator T* ();
Array::operator T* ()
{
return list;
}


#pragma once
#include <cassert>
//数组类模板定义
template<class T>
class Array {
private:
    T* list;//T型指针,用于存放动态分配的数组内存首地址
    int size;//数组大小(元素个数)
public:
    Array(int sz = 50);//构造函数
    Array(const Array<T>& a);//复制构造函数
    ~Array();//析构函数
    Array<T>& opeator = (const Array<T>&rhs);//重载“=”使数组对象可以整体赋值
    T& opeator[](int i);//重载“[ ]”,使Array对象可以起到C++普通数组的作用
    const T& operator[](int n)const;//“[ ]”运算符的const版本
    operator T* ();//重载到T*类型的转换,使Array对象可以起到C++普通数组的作用
    operator const T* ()const;//const版
    int getSize()const;//取数组大小
    void resize(int sz);//修改数组大小

};
//构造函数
template<class T>
Array<T>::Array(int sz) {
    assert(sz >= 0);//sz为数组大小,应当非负
    size = sz;//将元素个数赋值给变量size
    list = new T[size];//动态分配size个T类型的元素空间
}

//析构函数
template<class T>
Array<T>::~Array()
{
    delete[]list;
}

//复制构造函数
template<class T>
Array<T>::Array(const Array<T>& a)
{
    //从对象x取得数组大小,并复制给当前对象的成员
    size = a.size;
    //为对象申请内存并进行出错检查
    list = new T[size];//动态分配n个T类型的空间
    //从对象X复制数组元素到本对象
    for (int i = 0; i < size; i++)
        list[i] = a.list[i];
}

//重载“=”运算符,将对象rhs复制给本对象,实现对象间的整体赋值、
template<class T>
Array<T>& Array<T>::operator=(const Array<T>& rhs)
{
    //如果本对象中数组大小与rhs不同。则删除数组原有内存,然后重新分配
    if (size != rhs.size)
    {
        delete[]list;//删除数组原有内存
        size = rhs.size;//设置本对象的数组大小
        list = new[size];//重新分配n个元素的内存
    }
    //从对象X复制数组元素到本对象
    for (int i = 0; i < size; i++)
    {
        list[i] = rhs.list[i];
    }
    return *this;
}
//重载下标运算符,实现与普通数组一样通过下标访问元素,并具有越界检查的功能
template<class T>
T& Array<T>::operator[](int n)const
{
    assert(n >= 0 && n < size);
    return list[n];
}
//重载指针转换运算符,将Array类的对象名转换为T类型的指针,指向当前对象中的私有数组
//因而可以像使用普通数组一样使用Array类的对象名
template<class T>
Array<T>::operator T* ()
{
    return list;
}

template<class T>
Array<T>::operator const T* ()const
{
    return list;
}
//取当前数组的大小
template<class T>
int Array<T>::getSize()const
{
    return size;
}
//将数组大小修改为sz
template<class T>
void Array<T>::resize(int sz)
{
    assert(sz >= 0);
    if (sz == size)
    {
        return;
    }
    T* newList = new T[sz];
    int m = (sz < size) ? sz : size;
    //将原有数组中前n个复制到新数组中
    for (int i = 0; i < n; i++)
    {
        newList[i] = list[i];
        delete[]list;//删除元数组
        list = newList;//使list指向新数组
        size = sz;//更新size;
    }
}

重载指针转换运算符,需要有类型
这里是重载