Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
189 / 159 / 35
Регистрация: 22.05.2013
Сообщений: 455
Записей в блоге: 1
1

Шаблон класса и дружественная функция

17.07.2013, 14:38. Просмотров 1179. Ответов 6
Метки нет (Все метки)

Доброго времени суток. Столкнулся с непониманием одного процесса. Задача звучит следующим образом:
Написать шаблон функции isEqualTo для сравнения 2-х параметров. Использовать эту функцию с объектом класса.
Для этого нужно перегрузить оператор ==.
Если я перегружаю оператор сравнения как элемент класса, работает нормально
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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
template <class T>
bool isEqualTo(T &a, T &b)
{
    return (a == b);
}
 
template <class T>
class Test
{
public:
    Test(T x = 0, T y = 0) { a = x; b = y; }
    void print() const;
    bool operator == (Test<T> &);
 
private:
    T a;
    T b;
};
 
template <class T>
bool Test<T>::operator==(Test<T> &x)
{
    Test temp = *this;
    return (temp.a == x.a && temp.b == x.b);
}
 
 
template <class T>
void Test<T>::print() const
{
    cout << a << " " << b << endl;
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int x = 10, y = 10;
 
    cout << isEqualTo(x, y) << endl;
 
    Test<int> t(10, 10), t1(10, 10);
    cout << isEqualTo(t, t1) << endl;
 
    system("pause");
    return 0;
}

А если я пытаюсь сделать перегрузку оператора как дружественную функцию с 2-мя аргументами, то ничего не получается (уже несколько способов пробовал)
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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
template <class T>
bool isEqualTo(T &a, T &b)
{
    return (a == b);
}
 
template <class T>
class Test
{
    friend bool operator == (Test<T> &, Test<T> &);
public:
    Test(T x = 0, T y = 0) { a = x; b = y; }
    void print() const;
 
private:
    T a;
    T b;
};
 
 
template <class T>
bool operator == (Test<T> &x, Test<T> &y)
{
    return (x.a == y.a && x.b == y.b);
}
 
template <class T>
void Test<T>::print() const
{
    cout << a << " " << b << endl;
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int x = 10, y = 10;
 
    cout << isEqualTo(x, y) << endl;
 
    Test<int> t(10, 10), t1(10, 10);
    cout << isEqualTo(t, t1) << endl;
 
    system("pause");
    return 0;
}
Вопрос: где туплю?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.07.2013, 14:38
Ответы с готовыми решениями:

Дружественная функция класса
Проблема в том что дружественная функция класа механик в класе car (friend void update_status) не...

Дружественная шаблонная функция шаблонного класса
Не компилируется. Подскажите правильный синтаксис. template&lt;typename T&gt; class A;...

Дружественная функция и приватные члены класса
Здравствуйте, уважаемые форумчане! Подскажите, пожалуйста, можно ли как-то в коде ниже сделать...

Преобразование типа аргумента в тип класса и дружественная функция
Добрый день. Есть код: class Cls { private: double x; public: Cls(); Cls(double);

6
:)
Эксперт С++
4763 / 3257 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
17.07.2013, 16:00 2
Цитата Сообщение от Мимино Посмотреть сообщение
где туплю?
в классе:
C++
1
2
    template <class U>
    friend bool operator == (Test<U> &, Test<U> &);
2
136 / 128 / 59
Регистрация: 13.12.2012
Сообщений: 293
17.07.2013, 16:11 3
Не знаю, правильно это, или нет, но происходит все примерно так:
Здесь
C++
1
Test<int> t(10, 10), t1(10, 10);
происходит инстанцирование экземпляра Test<int>, т.е. создается класс, где T заменяется на int, соответственно, friend там выглядит примерно так:
C++
1
friend bool operator == (Test<int> &, Test<int> &);
Если есть слово friend, значит, эта функция видна в той же области видимости, где и находится класс (т.е., в нашем случае, в глобальной, где main)
И когда встречается вызов operator==(a,b), то встает выбор что вызывать, обычную функцию или шаблонную. У обычной приоритет больше, чем у шаблонной, соответственно, должна вызываться она, но она не определена, поэтому появляется LNK2019.
2
189 / 159 / 35
Регистрация: 22.05.2013
Сообщений: 455
Записей в блоге: 1
17.07.2013, 16:20  [ТС] 4
Tulosba,
Спасибо. Я правильно понимаю, что
C++
1
template <class T>
перед определением класса относится только к полям класса. А при объявлении дружественной функции это не работает и нужно
C++
1
2
template <class U>
    friend bool operator == (Test<U> &, Test<U> &);
Добавлено через 2 минуты
ViktorKozlov,
Если я явно указываю тип класса в заголовке функции вот так
C++
1
friend bool operator == (Test<int> &y, Test<int> &y);
то для int работает.

Добавлено через 4 минуты
Кажись доперло
ViktorKozlov, Спасибо за ссылку.
0
136 / 128 / 59
Регистрация: 13.12.2012
Сообщений: 293
17.07.2013, 17:06 5
Мимино,
У меня по прежнему LNK2019
функция то по-прежнему остается нешаблонной, и приоритет отдается ей. Ну а с параметрами
C++
1
int x = 10, y = 10;
работать будет в любом случае, так как для int'ов operator== стандартный
0
189 / 159 / 35
Регистрация: 22.05.2013
Сообщений: 455
Записей в блоге: 1
17.07.2013, 17:08  [ТС] 6
Вот так работает, но это не выход
C++
1
2
3
4
bool operator == (Test<int> &x, Test<int> &y)
{
    return (x.a == y.a && x.b == y.b);
}
C++
1
2
3
4
5
6
7
template <class T>
class Test
{
 
    friend bool operator == (Test<T> &, Test<T> &);
public:
...
0
Комп_Оратор)
Эксперт по математике/физике
8452 / 4211 / 573
Регистрация: 04.12.2011
Сообщений: 12,590
Записей в блоге: 14
17.07.2013, 20:05 7
Цитата Сообщение от Мимино Посмотреть сообщение
Вот так работает, но это не выход
Tulosba правильно говорит, если я правильно его понял:
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
template <class T>
bool isEqualTo(T &a, T &b)
{
    return (a == b);
}
 
template <class T>
class Test
{
public:
    Test(T x = 0, T y = 0) { a = x; b = y; }
    void print() const;
    Test(const T& x){
a=x.a;
b=x.b;
    }
 
 
template <typename T>
friend 
bool operator==(Test<T> &x, Test<T> &y);
 
private:
    T a;
    T b;
};
 
template <typename T>
bool operator==(Test< T> &x, Test< T> &y)
{
        return (y.a == x.a && y.b == x.b);
}
 
 
template <class T>
void Test<T>::print() const
{
    cout << a << " " << b << endl;
}
 
#include <iostream>
using namespace std;
int main()
{
setlocale(LC_ALL, "Russian");
    int x = 10, y = 10;
 
    cout << isEqualTo(x, y) << endl;
 
    Test<int> t(10, 10), t1(10, 10);
    cout << isEqualTo(t, t1) << endl;
 
cout<<endl;
cin.get();
return 0;
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.07.2013, 20:05

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Дружественная функция-оператор, доступ к закрытым полям класса
У меня есть класс MyClass, вот код: class MyClass { int x, y; public: MyClass(); friend...

Дружественная функция не может получить доступ к приватным данным класса
Доброго времени суток уважаемые форумчане), пытаюсь реализовать дружественную функцию которая берет...

Почему дружественная функция не может обратиться к protected полю класса?
Не могу понять, почему функция не может обратиться к protected полю класса: class Ships {...

Почему дружественная функция с перегруженным оператором << не имеет доступа к данным класса?
В заголовочном файле &quot;klass.h&quot; есть класс: class klass { int x; public: klass(); ~klass();...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.