|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
||||||
Шаблоны функции и указатель на функцию передаваемый в функцию19.05.2017, 05:16. Показов 8415. Ответов 38
Метки нет (Все метки)
Привет! Вопрос такой: Если я пишу сортировку, например, bubbleSort и хочу помимо массива и его размера передать ещё и указатель на функцию, которая будет отвечать за последовательность сортировки по убыванию или по возрастанию... но сортировка должна специализировать типы данных во время выполнения. Вот как я хотел сделать:
В чём моя ошибка, сам не могу разобраться, но ,уверен, что здесь помогут)
0
|
||||||
| 19.05.2017, 05:16 | |
|
Ответы с готовыми решениями:
38
Параметр передаваемый в функцию В функцию-метод передать указатель на другую функцию-метод и вызвать через переданный указатель |
|
Комп_Оратор)
|
||
| 21.05.2017, 21:18 | ||
0
|
||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
||||||
| 21.05.2017, 21:34 [ТС] | ||||||
И ещё если шаблон объявлен как template<typename elementType, int numberOfElements> , то как определить шаблон для второго параметр(объекта), если функция расположена вне определения шаблона класса, если так template<typename elementType1, int numberOfElements1> ошибка. Правильно я понял, что такое можно проделать только в определении шаблона класса?
0
|
||||||
|
Комп_Оратор)
|
||
| 21.05.2017, 21:43 | ||
0
|
||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
||||||
| 21.05.2017, 22:20 [ТС] | ||||||
|
Цель сделать шаблон класса Array этот класс писал автор книги в целях демонстрации перегрузки операций, в данной главе он требует сделать шаблон этого класса с Одним типовым параметром и одним нетиповым параметром, вот код:
Работает всё, кроме присваивания, точнее, как я и писал выше, если присваивать объекты одного типа и одинакового размера, то всё проходит, а если хотя бы размер не одинаков, то ошибка.
Объект array должен выполнять если не все, то хотя бы часть функций, которые выполняют массивы в стиле C, но при это нужно контролировать выход за пределы массива, заполнение массива значениями, вывод массива(в табулированной форме), присваивание одного массива другому, присваивание литерала объекту, сравнение объектов(массивов) вот вкратце и всё, думаю, на начальном этапе хватит. тут цель не добавить функционал, а разобраться, как работать с шаблонами классов, я так думаю)
0
|
||||||
|
Комп_Оратор)
|
|||||||||
| 21.05.2017, 22:58 | |||||||||
Идея написать кучу специализаций для осуществления присваивания массивов разных типов тоже не вдохновляет. Может пусть ограничится своим типом? ![]() При присваивании разно размерных однотипных даже: Дело в том, что класс это только оболочка. Внутри у Вас массив. При несовместимости по размеру придётся удалить и создать новый. Так не проще ли сконструировать новый экземпляр класса?
0
|
|||||||||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
|||||||||||
| 21.05.2017, 23:48 [ТС] | |||||||||||
Всё остальное это мои предположения и желания чуть-чуть понять работу шаблонов классов и функций так как очень слабо владею этипм предметом. По сути я задание зделал, создаю объект в майне, как он, автор книги, и требует, а какие-то действия с этими объектами не предусмотрены в задании. или я чего-то недопонял. Короче говоря, в данном случае, не стоит заморачиваться с выделением места для нового массива. С указателями проще, удалил delete[] ptr выделит new место под новый размер и радуйся, а тут значит так не пройдёт. Что ж это то, что я и хотел узнать.Кликните здесь для просмотра всего текста
поперегружал уже.
0
|
|||||||||||
|
Комп_Оратор)
|
|||||||||
| 22.05.2017, 00:52 | |||||||||
![]() Добавлено через 44 минуты Вот перед сном всё о том же:
0
|
|||||||||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
||||||||||||
| 22.05.2017, 04:56 [ТС] | ||||||||||||
|
В классах везде значит надо писать
Правильно понимаю, что в коде, для задания, явная реализаця операции присваивания не нужна? Что значит: переопределить шаблон явным определением класса Array для типа float? Заново что ли писать класс только с заголовком
0
|
||||||||||||
|
Комп_Оратор)
|
|||||||||
| 22.05.2017, 09:22 | |||||||||
|
В таком роде:
0
|
|||||||||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
|||||||||||
| 22.05.2017, 21:17 [ТС] | |||||||||||
, а я тем более. Если с шаблоном функции, то понятно, пишется шаблонная/не шаблонная функция с тем же именем, но разными параметрами и реализацией. А тут возник вопрос, где его писать, отдельно от уже созданного класса Array(у меня Test) или внутри как-то приспасабливать, если отдельно, то как это выглядит при подключении в файле main() там у меня уже подключен Test.h вопрос в этом в основном. А так я тоже накалякал кое что) Кликните здесь для просмотра всего текста
Но меня терзают смутные сомнения, если честно. Кликните здесь для просмотра всего текста
0
|
|||||||||||
|
Комп_Оратор)
|
|||
| 22.05.2017, 21:55 | |||
![]() В данном случае, неуверенность связана с тем, что я не вижу всей задачи (её текста) и поэтому вынужден немного гадать. Однако, возвращаясь к теме, - явная специализация, это перегрузка шаблона для конкретного случая. Она имеет смысл если логика для указанного случая отличается от общего алгоритма. Пример я показал. Как смог.
0
|
|||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
|||||||
| 23.05.2017, 06:15 [ТС] | |||||||
|
Кликните здесь для просмотра всего текста
0
|
|||||||
|
Комп_Оратор)
|
|||
| 23.05.2017, 08:08 | |||
|
Вопрос вроде:
0
|
|||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
|||||||
| 23.05.2017, 20:36 [ТС] | |||||||
дело оказалось вот в чём, у меня студия старая, как ...авно мамонта, я решил попробовать откомпилировать на 2008 и 2010 на них код нормально компилируется-линкуется и работает как надо, как требует автор в задании.Вот код: Кликните здесь для просмотра всего текста
Но ещё много вопросов осталось по этой теме.
0
|
|||||||
|
Комп_Оратор)
|
|||
| 23.05.2017, 20:45 | |||
size и пользуйтесь numberOfElements. Указатель как член вам тоже не нужен - уберите и elementType* sPtr;Избавьтесь от выделения и освобождения явно. Если у Вас есть массив elementType array[numberOfElements]; то не нужно ничего. Только имя пересекается с std::array но это не страшно. Это гадко, но пока не зацепит не поймёте. У меня например arra и др. Я не горжусь данными изысками, но думаете это от пресыщенности бытиём я сочиняю? Остальное не смотрел. Чтобы не огорчать. Но в целом, если Вам нравится, то это уже результат. ![]() добавлю уже при редактировании данного повтора. 15 секунд это не спроста. Это !%. Думаю внечеловеческий разум пытается нам рассказать, что !% это повторение. Хотя не уверен. Добавлено через 15 секунд size и пользуйтесь numberOfElements. Указатель как член вам тоже не нужен - уберите и elementType* sPtr;Избавьтесь от выделения и освобождения явно. Если у Вас есть массив elementType array[numberOfElements]; то не нужно ничего. Только имя пересекается с std::array но это не страшно. Это гадко, но пока не зацепит не поймёте. У меня например arra и др. Я не горжусь данными изысками, но думаете это от пресыщенности бытиём я сочиняю? Остальное не смотрел. Чтобы не огорчать. Но в целом, если Вам нравится, то это уже результат.
0
|
|||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
||
| 23.05.2017, 21:21 [ТС] | ||
По поводу того, что убрать указатель и size я это понял. Если бы я захотел создавать объекты массива Test<тип> test, а не Test<тип, количество>, то для этого нужно создавать ещё один класс, допустим так: template<typename T> class Test{//....}; так? явно специализировать не поучиться ведь? По сути это идентичный по функционалу класс получится, а значит займёт лишнюю память это же не айс.
0
|
||
|
Комп_Оратор)
|
||
| 23.05.2017, 21:49 | ||
|
Далее массив объекта a Вы заселили последовательностью 1, 2, 3 b и с содержат мусор. Поскольку Ваш класс не зависит от размера то a,b,c это один и тот же тип то Вы можете присвоить любой любому в любой последовательности. Теперь если b=a всё нормально, - в b содержатся 1, 2, 3. А вот если с=a то семь элементов не содержат ничего хорошего. Как быть? Контролировать размер достоверных данных? Это путь на Голгофу. Менять размер перевыделением? Лучше уже путь на Голгофу. Дело в том, что создать новый объект может оказаться проще, чем перевыделять старый. Хотя если интересно - сделайте. Но лучше бы всё это поделать без шаблонов.
0
|
||
|
225 / 39 / 4
Регистрация: 18.11.2012
Сообщений: 1,633
|
|||
| 23.05.2017, 23:29 [ТС] | |||
|
0
|
|||
|
Комп_Оратор)
|
|||
| 24.05.2017, 08:54 | |||
|
Ещё раз. Если вы объявляете константу определяющую размер параметром шаблона, это автоматически ведёт к созданию встроенного локального массива. Если не ломать свою же логику. Иначе такой параметр не нужен. И вреден. Вы же пишете библиотеку не для того чтобы получать судебные иски от юзеров с обвинениями в крайних формах мизантропии?
0
|
|||
| 24.05.2017, 08:54 | |
|
Ограничен ли буфер, передаваемый в функцию send Работа с файлом (передать указатель на файл в функцию, вернуть указатель на файл из функции) Можно ли в C++ определить функцию, которая возвращает указатель на функцию с той же сигнатурой?
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Doom для терминала без стрельбы и монстров. 3D Raycasting на ascii.
dcc0 05.07.2026
Попросил нейронную сеть deepai. org написать рейкастинг 3D с библиотекой ncurses для Linux. Чтобы можно было
ходить на стрелочки. Чтобы стены были отрисованы символами. Справилась.
Первый вариант. . .
|
Установка статуса документа по условию
Maks 05.07.2026
Алгоритм из решения ниже реализован на нетиповом документе "НарядПутевка" разработанного в КА2.
Задача: в табличной части "Материалы" документа при записи автоматически устанавливать статус. . .
|
Сезонность и суточность закисления почв
anaschu 04.07.2026
200 часов это все равно моловато. Есть ситуации, но нестандартные, когда смена происходит за 5 лет.
Но обычно это 50 лет и более.
Наверное, закисление почвы происходит сезонно в средней. . .
|
В чем ценность человеческого опыта в глобальном смысле?
kumehtar 03.07.2026
Возможно, ценность человека не в том, что он однажды достигает мудрости, а в том, что он становится носителем карты пути. Он знает не только истину, но и последовательность внутренних изменений,. . .
|
|
интеграция AnyLogic с самописным REST API и переход на Odoo
anaschu 03.07.2026
Успешная интеграция AnyLogic с самописным REST API и переход на промышленную Odoo WMS
Сегодня проделал огромный путь от простой симуляции физических процессов до построения полноценной. . .
|
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи.
Через несколько переработок от PHP кода к C89 (надеюсь, 89).
Но довольно запутанно получилось. Код для Linux.
Но если убрать time и то, что с ним. . .
|
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки
Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
|
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы
Всем привет! Хочу поделиться свежим (и довольно. . .
|