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

Шаблоны. Нетиповые параметры - C++

Восстановить пароль Регистрация
 
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
17.07.2013, 22:18     Шаблоны. Нетиповые параметры #1
Доброго времени суток. Столкнулся с проблемой. В учебнике, по которому я занимаюсь, о нетиповых параметрах написан всего 1 абзац , зато задачи присутствуют. Вот одна из них:
Написать шаблон класса Array с использованием нетипового параметра numberOfElements, который определяет количество элементов массива.
Ничего толком не зная о нетиповых параметрах я создал это (все постить не буду, ошибки пошли сразу же начиная с конструктора )
Класс:
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
template <class elementType, int numberOfElements>
class Array
{
    template <class elementType1, int numberOfElements1>
    friend ostream &operator <<(ostream &, const Array<elementType1, numberOfElements1> &);
    template <class elementType1, int numberOfElements1>
    friend istream &operator >>(istream &, Array<elementType1, numberOfElements1> &);
 
public:
    Array();
    Array(const Array<elementType, numberOfElements> &);
    ~Array();
    int getSize() const;
    const Array &operator = (const Array<elementType, numberOfElements> &);
    int operator == (const Array<elementType, numberOfElements> &) const;
    int operator != (const Array<elementType, numberOfElements> &) const;
    elementType &operator [](int);
 
 
private:
    elementType *ptr;
    int size;
};
#endif
Конструктор
C++
1
2
3
4
5
6
7
8
9
10
template <class elementType, int numberOfElements>
Array<elementType, numberOfElements>::Array()
{
    size = numberOfElements;
    ptr = new elementType[size];
    assert(ptr != 0);
 
    for (int i = 0; i < size; i++)
        ptr[i] = 0;
}
Ну и сразу же ожидаемая ошибка после объявления в мейне Array<int, 7> integers1;
1>Job 12 7.obj : error LNK2001: unresolved external symbol "public: __thiscall Array<int,7>::~Array<int,7>(void)" (??1?$Array@H$06@@QAE@XZ)
1>Job 12 7.obj : error LNK2001: unresolved external symbol "public: __thiscall Array<int,7>::Array<int,7>(void)" (??0?$Array@H$06@@QAE@XZ)
В гугле много инфы не нашел. Самое полезное
template <class T, int size>// реализация параметризованного члена-функции
void A<T, size>::func() {
}
то есть я вроде бы все правильно сделал.
Что мне нужно:
1. Статью, главу учебника, ссылку где я смогу прочитать и (тут самое главное) ПОНЯТЬ, как работать с нетиповыми параметрами
2. Простой пример(можно прямо на моем классе), который расставит все точки над i;
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.07.2013, 22:18     Шаблоны. Нетиповые параметры
Посмотрите здесь:

C++ шаблоны
C++ Шаблоны
Параметры функции через шаблоны C++
C++ шаблоны и параметры
Шаблоны С++ C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
17.07.2013, 22:26     Шаблоны. Нетиповые параметры #2
Реализацию деструктора напишите

Добавлено через 24 секунды
Цитата Сообщение от Мимино Посмотреть сообщение
Статью, главу учебника, ссылку где я смогу прочитать и (тут самое главное) ПОНЯТЬ, как работать с нетиповыми параметрами
Например, "C++ для профессионалов"
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
17.07.2013, 22:29     Шаблоны. Нетиповые параметры #3
рекумендую такую книжку:
Шаблоны C++: справочник разработчика

picГод выпуска: 2003
Автор: Дэвид Вандевурд, Николай М. Джосаттис
Издательство: Вильямc
ISBN: 5-8459-0513-3
Формат: DjVu
Качество: Отсканированные страницы
Количество страниц: 544
http://rutracker.org/forum/viewtopic.php?t=758806

сабжевой теме посвящена глава 4.


C++
1
2
3
4
5
// все не смотрел. что видно сразу:
   ptr = new elementType[size];
// надо поменят на 
   ptr = new elementType[numberOfElements];
// size - не константа времени компиляции, в отличии от   numberOfElements
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
17.07.2013, 22:32  [ТС]     Шаблоны. Нетиповые параметры #4
Цитата Сообщение от Croessmah Посмотреть сообщение
Реализацию деструктора напишите
C++
1
2
3
4
5
template <class elementType, int numberOfElements>
Array<elementType, numberOfElements>::~Array()
{
    delete [] ptr;
}
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
17.07.2013, 22:34     Шаблоны. Нетиповые параметры #5
Мимино, я к тому, что нет реализации конструктора и деструктора:
1>Job 12 7.obj : error LNK2001: unresolved external symbol "public: __thiscall Array<int,7>::~Array<int,7>(void)" (??1?$Array@H$06@@QAE@XZ)
1>Job 12 7.obj : error LNK2001: unresolved external symbol "public: __thiscall Array<int,7>::Array<int,7>(void)" (??0?$Array@H$06@@QAE@XZ)
Цитата Сообщение от Мимино Посмотреть сообщение
C++
1
#endif
Вы случайно не разделили объявление и реализацию на разные файлы?
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
17.07.2013, 22:35  [ТС]     Шаблоны. Нетиповые параметры #6
Цитата Сообщение от Croessmah Посмотреть сообщение
Например, "C++ для профессионалов"
Мне б для новичков что то. 2 месяца только с++ учу.

Добавлено через 43 секунды
Цитата Сообщение от Croessmah Посмотреть сообщение
Вы случайно не разделили объявление и реализацию?
Да, конечно... то случайно затисалось. Во весь хидер
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
#ifndef ARRAY1_H
#define ARRAY1_H
#include <iostream>
using namespace std;
 
template <class elementType, int numberOfElements>
class Array
{
    template <class elementType1, int numberOfElements1>
    friend ostream &operator <<(ostream &, const Array<elementType1, numberOfElements1> &);
    template <class elementType1, int numberOfElements1>
    friend istream &operator >>(istream &, Array<elementType1, numberOfElements1> &);
 
public:
    Array();
    Array(const Array<elementType, numberOfElements> &);
    ~Array();
    int getSize() const;
    const Array &operator = (const Array<elementType, numberOfElements> &);
    int operator == (const Array<elementType, numberOfElements> &) const;
    int operator != (const Array<elementType, numberOfElements> &) const;
    elementType &operator [](int);
 
 
private:
    elementType *ptr;
    int size;
};
#endif
Добавлено через 42 секунды
А вот весь .cpp
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
#include "stdafx.h"
#include "array1.h"
#include <iostream>
#include <assert.h>
#include <stdlib.h>
using namespace std;
 
template <class elementType, int numberOfElements>
Array<elementType, numberOfElements>::Array()
{
    size = numberOfElements;
    ptr = new elementType[size];
    assert(ptr != 0);
 
    for (int i = 0; i < size; i++)
        ptr[i] = 0;
}
 
template <class elementType, int numberOfElements>
Array<elementType, numberOfElements>::Array(const Array<elementType, numberOfElements> &init)
{
    size = init.size;
    ptr = new elementType[size];
    assert(ptr != 0);
 
    for (int i = 0; i < size; i++)
        ptr[i] = init.ptr[i];
}
 
template <class elementType, int numberOfElements>
Array<elementType, numberOfElements>::~Array()
{
    delete [] ptr;
}
 
template <class elementType, int numberOfElements>
int Array<elementType, numberOfElements>::getSize() const
{
    return size;
}
 
template <class elementType, int numberOfElements>
const Array<elementType,numberOfElements> &Array<elementType, numberOfElements>::operator = (const Array<elementType, numberOfElements> &right)
{
    if (right != this)
    {
        delete [] ptr;
        size = right.size;
        ptr = new elementType[size];
        assert(ptr != 0);
 
        for (int i = 0; i < size; i++)
            ptr[i] = right.ptr[i];
    }
 
    return *this;
}
 
template <class elementType, int numberOfElements>
int Array<elementType, numberOfElements>::operator==(const Array<elementType, numberOfElements> &right) const
{
    if (size != right.size)
        return 0;
    for (int i = 0; i < size; i++)
        if (ptr[i] != right.ptr[i])
            return 0;
    return 1;
}
 
template <class elementType, int numberOfElements>
int Array<elementType, numberOfElements>::operator!=(const Array<elementType, numberOfElements> &right) const
{
    if (size != right.size)
        return 1;
    for (int i = 0; i < size; i++)
        if (ptr[i] != right.ptr[i])
            return 1;
    return 0;
}
 
template <class elementType, int numberOfElements>
elementType &Array<elementType, numberOfElements>::operator[](int subscript)
{
    assert(0 <= subscript && subscript < size);
 
    return ptr[subscript];
}
 
template <class elementType1, int numberOfElements1>
ostream &operator <<(ostream &output, const Array<elementType1, numberOfElements1> &a)
{
    int i;
    for (i = 0; i < a.size; i++)
    {
        output << a.ptr[i] << ' ';
        if ((i + 1) % 10 == 0)
            output << endl;
    }
 
    if (i % 10 != 0)
        output << endl;
 
    return output;
 
}
 
 
template <class elementType1, int numberOfElements1>
istream &operator >>(istream &input, const Array<elementType1, numberOfElements1> &a)
{
    for (int i = 0; i < a.size; i++)
        input >> a.ptr[i];
 
    return input;
 
}
Croessmah
Модератор
Эксперт С++
 Аватар для Croessmah
11822 / 6801 / 769
Регистрация: 27.09.2012
Сообщений: 16,869
Записей в блоге: 2
Завершенные тесты: 1
17.07.2013, 22:37     Шаблоны. Нетиповые параметры #7
Цитата Сообщение от Мимино Посмотреть сообщение
Да, конечно...
Делайте всё в одном файле. Код шаблона должен быть доступен для инстанцирования.
Шаблон - это только описание того, как объект устроен, он не несет в себе другой информации.
Olivеr
 Аватар для Olivеr
411 / 407 / 13
Регистрация: 06.10.2011
Сообщений: 830
17.07.2013, 22:44     Шаблоны. Нетиповые параметры #8
А зачем выделять место в куче? Массив то фиксированный.
Достаточно сделать так:
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
#include <iostream>
#include <cstdint>
 
template <class T, uint64_t Size>
class array
{
    T arr[Size];
public:
    array() {}
    T& operator [] (uint64_t idx)
    { return arr[idx]; }
    T& operator [] (uint64_t idx) const;
    uint64_t size() const { return Size; }
    ~array() {}
};
 
template <class T, uint64_t Size>
T& array<T, Size>::operator [] (uint64_t idx) const
{ return arr[idx]; }
 
int main()
{
    array<int, 10> arr;
    for (int i = 0; i != arr.size(); ++i)
        arr[i] = i + 1;
    for (int i = 0; i != arr.size(); ++i)
        std::cout << arr[i];
    return 0;
}
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
18.07.2013, 10:26  [ТС]     Шаблоны. Нетиповые параметры #9
Цитата Сообщение от Croessmah Посмотреть сообщение
Делайте всё в одном файле. Код шаблона должен быть доступен для инстанцирования.
Шаблон - это только описание того, как объект устроен, он не несет в себе другой информации.
Блин, а я его 2 раза переписывал
Для удобства запихнул все в хидер. Спасибо большое.

Добавлено через 1 минуту
Цитата Сообщение от Olivеr Посмотреть сообщение
А зачем выделять место в куче? Массив то фиксированный.
Достаточно сделать так:
Да, я знаю. Шаблон писался с обычного класса, поэтому я старался менять по-минимуму, чтобы не запутаться.

Добавлено через 11 часов 36 минут
Осталась еще одна непонятная мне ситуация.
Все перегруженные операторы сравнения и присваивания, например
C++
1
2
3
4
5
6
7
8
9
10
template <class elementType, int numberOfElements>
int Array<elementType, numberOfElements>::operator==(const Array<elementType, numberOfElements> &right) const
{
    if (size != right.size)
        return 0;
    for (int i = 0; i < size; i++)
        if (ptr[i] != right.ptr[i])
            return 0;
    return 1;
}
работают только в случае одинаковых нетиповых праметров numberOfElements. Для каждого уникального параметра создается свой шаблонный класс или как?
OhMyGodSoLong
~ Эврика! ~
 Аватар для OhMyGodSoLong
1234 / 983 / 42
Регистрация: 24.07.2012
Сообщений: 2,002
18.07.2013, 10:35     Шаблоны. Нетиповые параметры #10
Цитата Сообщение от Мимино Посмотреть сообщение
Для каждого уникального параметра создается свой шаблонный класс или как?
Ага.
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
18.07.2013, 10:38     Шаблоны. Нетиповые параметры #11
именно так. для компилятора классы, выведенные из шаблонов с разными аргументами - это разные классы. поэтому такие операторы нужно делать шаблонными. какие-то примеры есть в вышеприведенной книге в главе пять. там шаблонные операторы =.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.07.2013, 10:48     Шаблоны. Нетиповые параметры
Еще ссылки по теме:

Шаблоны C++
C++ Шаблоны как параметры
C++ Параметры-шаблоны у шаблонных классов

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

Или воспользуйтесь поиском по форуму:
Мимино
 Аватар для Мимино
180 / 151 / 5
Регистрация: 22.05.2013
Сообщений: 435
Записей в блоге: 1
18.07.2013, 10:48  [ТС]     Шаблоны. Нетиповые параметры #12
Понял, спасибо.
Yandex
Объявления
18.07.2013, 10:48     Шаблоны. Нетиповые параметры
Ответ Создать тему
Опции темы

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