Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
17.07.2013, 14:38     Шаблон класса и дружественная функция #1
Доброго времени суток. Столкнулся с непониманием одного процесса. Задача звучит следующим образом:
Написать шаблон функции 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;
}
Вопрос: где туплю?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.07.2013, 14:38     Шаблон класса и дружественная функция
Посмотрите здесь:

Преобразование типа аргумента в тип класса и дружественная функция C++
Почему дружественная функция с перегруженным оператором << не имеет доступа к данным класса? C++
Переопределение операторов как член-класса и как дружественная функция C++
Дружественная функция, объявлённая ранее вне пространства имён класса -> error LNK2019 в Visual Studio 2012 C++
C++ Дружественная функция
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Tulosba
:)
Эксперт C++
4377 / 3220 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
17.07.2013, 16:00     Шаблон класса и дружественная функция #2
Цитата Сообщение от Мимино Посмотреть сообщение
где туплю?
в классе:
C++
1
2
    template <class U>
    friend bool operator == (Test<U> &, Test<U> &);
ViktorKozlov
133 / 125 / 2
Регистрация: 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.
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 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, Спасибо за ссылку.
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
17.07.2013, 17:06     Шаблон класса и дружественная функция #5
Мимино,
У меня по прежнему LNK2019
функция то по-прежнему остается нешаблонной, и приоритет отдается ей. Ну а с параметрами
C++
1
int x = 10, y = 10;
работать будет в любом случае, так как для int'ов operator== стандартный
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 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:
...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.07.2013, 20:05     Шаблон класса и дружественная функция
Еще ссылки по теме:

Дружественная функция-оператор, доступ к закрытым полям класса C++
C++ Дружественная функция шаблон и ошибка "Ссылка на неразрешенный внешний символ"
C++ Дружественная функция класса

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

Или воспользуйтесь поиском по форуму:
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6156 / 2885 / 281
Регистрация: 04.12.2011
Сообщений: 7,680
Записей в блоге: 3
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;
}
Yandex
Объявления
17.07.2013, 20:05     Шаблон класса и дружественная функция
Ответ Создать тему
Опции темы

Текущее время: 05:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru