Форум программистов, компьютерный форум, киберфорум
Наши страницы

Не работает operator<< шаблонного класса Vector - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Ошибка при компиляции шаблонного вектора http://www.cyberforum.ru/cpp-beginners/thread931176.html
Написал вот такой код: #include <cstring> #include <iostream> #include <cassert> using namespace std; template < class T > class Vector { private: T* mas;
C++ convert char to hex Здравствуйте. Подскажите пожалуйста как преобразовать строку в hex? То есть имеем функцию convert(char param) { return hex; } http://www.cyberforum.ru/cpp-beginners/thread931174.html
C++ Как работает вставка в двусвязном списке?
Привет всем! я не понимаю как работает вставка в двусвязном списке, а точне не понимаю зачем писать нужно вот такую строку cur->next->prev = tmp; в функции insert() ? почему если написать такую...
C++ Прилинковать SDL к V.S. 2010
Доброго всем вечера. Я знаю, что подобных тем было много, но, справиться с проблемой не могу. Скачал с оф.сайта все .h, SDL.lib, SDLmain.lib и SDL.dll. dll поместил в System32, либы и .h собрал в...
C++ Вывод текста на консольное окно http://www.cyberforum.ru/cpp-beginners/thread931155.html
Всем привет! подскажите пожалуйста, во время вывода текста как перевести курсор на следующую строку?
C++ Оптимизация, редактирование кода Здраствуйте! Пишу крестики-нолики, но одно меня смущает, как это можно оптимизировать, поставить на цикл, а то ниче в голову не лезет. И можно ли как-то с помощью условной операции чередовать в этом... подробнее

Показать сообщение отдельно
k_flynn
0 / 0 / 0
Регистрация: 21.07.2013
Сообщений: 7

Не работает operator<< шаблонного класса Vector - C++

30.07.2013, 23:35. Просмотров 586. Ответов 14
Метки (Все метки)

Компилятор выдает ошибку error LNK2019: unresolved external symbol "class std::basic_ostream<char,struct std::char_traits<char> > & __cdecl operator<<... referenced in function _main
Помогите дураку докончить злополучный код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#include <cstring>
#include <iostream>
#include <cassert>
using namespace std;
 
template < class T > class Vector
{
private:
    T* mas;
    int size;
    int capacity;
public:
    Vector(); 
    Vector(int);
    Vector(const T*,int);
    Vector(const Vector&);
    ~Vector();
    int getSize() const;
    int getCapacity() const;
    /* double get(int pos) const
    {
        return mas[pos];
    }
    void set(double val, int pos)
    {
        mas[pos] = val;
        if (pos>=size)
        {
            size++;
        }
    } */
    void insert(T, int);
    void erase(int);
    T& operator  []  (int pos) 
    {
        return  mas[pos];
    } 
    const T& operator [] (int pos) const
    {
        return mas[pos];
    }
    friend bool operator == (const Vector<T>&, const Vector<T>&);
    friend bool operator == (const Vector<T>&, T op1);
    friend bool operator != (const Vector<T>&, const Vector<T>&);
    friend bool operator != (const Vector<T>&, T op1);
 
    friend ostream& operator << (ostream&, const Vector< T >);
};
 
template < typename T > Vector< T >::Vector()
{
    capacity = 10;
    size = 0;
    mas = new T [capacity];
}
template < typename T > Vector< T >::Vector(int capacity)
{
    size=0;
    this -> capacity = capacity;
    mas = new T [capacity];
}
template < typename T > Vector< T >::Vector(const T* ptr,int size)
{
    this->size = size;
    capacity = size+1;
    mas = new T[capacity];
    for(int i = 0; i<=size; i++)
    {
        mas[i]=ptr[i];
    }
}
template < typename T > Vector< T >::Vector(const Vector &a)
{
    size=a.size;
    capacity=a.capacity;
    mas = new T[capacity];
    for(int i = 0; i<=size; i++)
    {
        mas[i]=a.mas[i];
    }
}
template < typename T > Vector< T >::~Vector()
{
    delete[] mas;
}
template < typename T > int Vector< T >::getSize() const
{
    return size;
}
template <  typename T > int Vector< T >::getCapacity() const
{
    return capacity;
}
template < typename T > void Vector< T >::insert(T val, int pos)
{
    if(size == capacity)
    {
        this ->mas = new T [capacity*=2];
        for(int i = 0; i<size; i++)
            this -> mas[i]=mas[i];
    }
    for(int i=size; i>pos; i--)
    {
        mas[i]=mas[i-1];
    }
    mas[pos]=val;
    size++;
}
template < typename T > void Vector< T >::erase(int pos)
{
    for(int i=pos; i<size; i++)
        this -> mas[i] = this -> mas[i+1];
    size--;
}
template < typename T > bool operator == (const Vector<T> &ob1,const Vector<T> &ob2)
{
        if(ob1.size!=ob2.size)
        {
                return false;
 
                for(int i=0; i<=ob1.size; ++i)
                {
                        if(ob1.mas[i] != ob2.mas[i])
                        {
                                return false;
                        }
                }
                return true;
        }
}
template < typename T > bool operator == (const Vector<T> &ob1, T op1)
{
        int i;
        for(i=0; i<=ob1.size; ++i) 
        {
                if(ob1.mas[i] != op1)
                {
                        return false;
                }
        }
        return true;
}
template < typename T > bool operator != (const Vector<T> &ob1,const Vector<T> &ob2)
{
        return !(ob1 == ob2);
}
 
template < typename T > bool operator != (const Vector<T> &ob1, T op1)
{
        return !(ob1 == op1);
}
 
struct day_in_year{
    int month, day;
    day_in_year(int d=1, int m=1):day(d),month(m){}
};
 
std::ostream& operator<<(std::ostream& out, const day_in_year& diy){
    out << diy.day << "." << diy.month;
    return out;
}
 
int main(){
 
Vector<day_in_year> b(20);
b.insert(day_in_year(3,3), 0);
b.insert(day_in_year(3,2), 0);
cout << b << "\n";
cout << b.getSize() << ' ' << b.getCapacity() << '\n';
 
b.erase(1);     // leave 3.2
cout << b.getSize() << '\n';
for(int i=0; i<20; i++){
    b.insert(day_in_year(i,i/5), b.getSize());
}
cout << b.getSize() << '\n';
cout << b[b.getSize()-1] << '\n';
assert(b.getCapacity() >= b.getSize());
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru