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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
#1

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

17.07.2013, 14:38. Просмотров 511. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.07.2013, 14:38
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Шаблон класса и дружественная функция (C++):

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

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

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

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

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

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

6
Tulosba
:)
Эксперт С++
4397 / 3233 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
17.07.2013, 16:00 #2
Цитата Сообщение от Мимино Посмотреть сообщение
где туплю?
в классе:
C++
1
2
    template <class U>
    friend bool operator == (Test<U> &, Test<U> &);
2
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.
2
Мимино
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, Спасибо за ссылку.
0
ViktorKozlov
133 / 125 / 2
Регистрация: 13.12.2012
Сообщений: 293
17.07.2013, 17:06 #5
Мимино,
У меня по прежнему LNK2019
функция то по-прежнему остается нешаблонной, и приоритет отдается ей. Ну а с параметрами
C++
1
int x = 10, y = 10;
работать будет в любом случае, так как для int'ов operator== стандартный
0
Мимино
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:
...
0
IGPIGP
Комп_Оратор)
Эксперт по математике/физике
6503 / 3142 / 307
Регистрация: 04.12.2011
Сообщений: 8,673
Записей в блоге: 5
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
17.07.2013, 20:05
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.07.2013, 20:05
Привет! Вот еще темы с ответами:

Дружественная функция шаблон и ошибка "Ссылка на неразрешенный внешний символ" - C++
#include &lt;iostream&gt; using namespace std; template&lt;class T&gt; class random; template&lt;class T&gt; void f(random&lt;int&gt;); ...

Дружественная функция, объявлённая ранее вне пространства имён класса -> error LNK2019 в Visual Studio 2012 - C++
Всем привет. Долгое время пытался откопать ответ в гугле, но не получилось. Заранее благодарен. void f(){}; namespace space { ...

Переопределение операторов как член-класса и как дружественная функция - C++
Привет. Задача создать класс целых чисел, для него нужно переопределить операторы ++ и + как функции-члены и -- и - как дружественные...

Дружественная функция - C++
Хочу сделать вычисление площади как дружественную функцию, начал описывать, дальше догнать не могу как кодить. Подскажите? #include...


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

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

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