Перегруженный оператор% от нормального класса, вложенный в класс шаблона, определенный вне класса

У меня проблема с определением оператора% вне моего шаблона. Я решил эту проблему, делая это внутри, но я хотел бы знать, почему это не работает по-другому.

Вот мой код:

namespace std{
    class vector{};class deque{};class list{};class multiset{};class set{}; class map{}; class multimap{};
};

//---------------------------------------

namespace oop{
    template<typename T> class Array{
        public:
            class value_type{
                public:
                    value_type(T val):_val(val){};
                    T _val;
            };
            Array(int size);
            Array& insert(T ob);
            virtual ~Array(){delete [] _arr;};
            static unsigned int _inserted;
            T& operator[](int i){return _arr[i];};
            Array& operator%(const value_type& right){this->insert(right._val);Array& ref=*this; return ref;};  // inside class it works fine
            unsigned int operator~(){return _inserted;}
        private:
            T* _arr;
            int _size;
    };

    template<typename T> unsigned int Array<T>::_inserted=0;

    template<typename T> Array<T>::Array(int size){
        _size=size;
        _arr=new T[size];
    }

    template<typename T> Array<T>& Array<T>::insert(T ob){
        _arr[Array<T>::_inserted]=ob;
        Array<T>::_inserted++;
        Array<T>& ref=*this;
        return ref;
    }

// But outside it throws an error during compilation: "'oop::Array<T>::value_type' is not a type"
//
//              |
//              v
//
//  template<typename T> Array<T>& operator%(Array<T>& left, Array<T>::value_type & right){
//      left.insert(right._val);                                
//      return left;
//  }
};

//---------------------------------------

#include<cstdlib>
#include<iostream>

//---------------------------------------

int main(){
    typedef oop::Array<char> type; 
    type a(rand()%10+5);
    a.insert('#').insert('C')%type::value_type('P')%type::value_type('P')%'&';
    for(unsigned int i=0; i!=~a; ++i)
        std::cout<<i<<":"<<a[i]<<((i+1)!=~a?" ":"\n");
    return 0;
}
//output: 0:# 1:C 2:P 3:P 4:&

Компилятор, кажется, рассматривает type_value как нечто иное, чем type, почему он?

0 ответов

Другие вопросы по тегам