Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/25: Рейтинг темы: голосов - 25, средняя оценка - 4.52
1 / 1 / 0
Регистрация: 07.04.2016
Сообщений: 66

Что означает "параметризованная функция"?

04.04.2017, 11:54. Показов 5450. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет! Я читал различные статьи где описывали сортировку данных и встретил вот такую штуку:

C
1
qsort() — параметризованная функция, благодаря чему она может обрабатывать широкий набор типов данных, но вместе с тем вследствие этого она работает медленнее, чем эквивалентная функция, рассчитанная на какой-то один тип данных.

Что означает "параметризованная функция"?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2017, 11:54
Ответы с готовыми решениями:

скажите пожалуйста, что означает здесь b. ,это какия-либо функция или что?
скажите пожалуйста, что означает здесь b. ,это какия-либо функция или что? //анализируем все клетки доски for(int i = 0; i <...

что эта функция означает ?
int MVector<T>::find(const T& value) const { int pos = -1; for(unsigned i = 0; i < m_size; ++i) { if(m_array...

Параметризованная функция вычисления среднего арифметического значения массива элементов
Опишите параметризованную функцию вычисления среднего арифметического значения мас- сива элементов

11
 Аватар для Kastaneda
5232 / 3205 / 362
Регистрация: 12.12.2009
Сообщений: 8,143
Записей в блоге: 2
04.04.2017, 12:02
Судя по описанию имелось ввиду, что она имеет шаблонные параметры, благодаря чему может работать с любым типом (соответсвующим type requirements).
Кстати вот это
Цитата Сообщение от java_user Посмотреть сообщение
но вместе с тем вследствие этого она работает медленнее, чем эквивалентная функция, рассчитанная на какой-то один тип данных.
чистая ложь, никакого замедления нет.
1
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
04.04.2017, 12:04
Лучший ответ Сообщение было отмечено java_user как решение

Решение

Kastaneda, но qsort не шаблонная, она просто в качестве последнего аргумента принимает указатель на функцию, который в свою очередь принимает 2 указателя на const void и возвращает int.
думаю медленнее она из-за кастов из войд куда-то там.
http://en.cppreference.com/w/cpp/algorithm/qsort
2
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
04.04.2017, 12:05
Цитата Сообщение от Kastaneda Посмотреть сообщение
Судя по описанию имелось ввиду, что она имеет шаблонные параметры, благодаря чему может работать с любым типом
если так, гуглите "template"
1
techpriest
 Аватар для Mirmik
634 / 213 / 57
Регистрация: 27.02.2014
Сообщений: 1,180
04.04.2017, 12:16
Лучший ответ Сообщение было отмечено java_user как решение

Решение

qsort - это функция из стандартной библиотеки си. Шаблоны тут не причем. Замедляется она из-за использования указателей на функцию сравнения.
Касты из войд времени вроде бы не занимают. Хотя хз... Может и занимают.
А вот вызов функции через указатель - занимает. Впрочем, немного...

Сложно сказать, что имел ввиду автор, когда назвал сию функцию параметризованной. То есть понятно, что это он и имел ввиду, но смысл фразы неочевиден.
1
1 / 1 / 0
Регистрация: 07.04.2016
Сообщений: 66
04.04.2017, 12:17  [ТС]
Цитата Сообщение от GoldenId Посмотреть сообщение
если так, гуглите "template"
Насколько мне известно "template" нет в Си, а qsort - это стандартная функция Си и она не шаблонная.
0
 Аватар для Kastaneda
5232 / 3205 / 362
Регистрация: 12.12.2009
Сообщений: 8,143
Записей в блоге: 2
04.04.2017, 12:19
Лучший ответ Сообщение было отмечено java_user как решение

Решение

Цитата Сообщение от GbaLog- Посмотреть сообщение
Kastaneda, но qsort не шаблонная
А, блин, да, я попутал. Тогда мой ответ выше не правильный.

Цитата Сообщение от GbaLog- Посмотреть сообщение
думаю медленнее она из-за кастов из войд куда-то там.
Думаю тут в другом дело, в первом посте у ТС'а правильно написано, что она медленней из-за того, что предназначена для всех типов сразу. Т.е. в С++ (в шаблонной версии сортировки) есть возможность сделать специализацию под конкретный тип, которая будет работать максимально быстро (ну или как минимум быстрее, чем обобщенный вариант) с этим типом. Знания о типе позволяют сделать обмен 2х элементов наименее затратно, например для целочисленных типов это можно сделать через ^ (xor), для других типов через доп. переменную и т.д. А тут void* полностью скрывает тип и нет возможности выбрать быструю реализацию для типа.

Добавлено через 35 секунд
GoldenId, Mirmik, java_user, да да, ошибку признал
1
Любитель чаепитий
 Аватар для GbaLog-
3745 / 1801 / 566
Регистрация: 24.08.2014
Сообщений: 6,020
Записей в блоге: 1
04.04.2017, 12:21
Цитата Сообщение от Kastaneda Посмотреть сообщение
Нет, в первом посте у ТС'а правильно написано, что она медленней из-за того, что предназначена для всех типов сразу.
да, я тоже попутал чего-то.
1
techpriest
 Аватар для Mirmik
634 / 213 / 57
Регистрация: 27.02.2014
Сообщений: 1,180
04.04.2017, 12:32
Kastaneda, qsort требует явно указать функцию сравнения, которая как раз может быть оптимизирована под реальный тип. Дело не в этом а в самом использовании указателя на функцию и, возможно, в том, что размер объекта задаётся рантайм переменной, а не константой компиляции (если размер жестко вписан в код, это однозначно не медленнее, хотя не факт, что быстрее).

Впрочем, я также хочу отметить, что не факт, что сортировка с применением с++ алгоритмов будет работать быстрее. Зависит от того, насколько хорошо оптимизатор это дело отрабатывает .
1
 Аватар для Kastaneda
5232 / 3205 / 362
Регистрация: 12.12.2009
Сообщений: 8,143
Записей в блоге: 2
04.04.2017, 12:40
Цитата Сообщение от Mirmik Посмотреть сообщение
qsort требует явно указать функцию сравнения, которая как раз может быть оптимизирована под реальный тип.
Но сравнение 2х элементов быстрее обмена 2х элементов, поэтому думаю функция сравнения тут роли не играет.
Цитата Сообщение от Mirmik Посмотреть сообщение
Дело не в этом а в самом использовании указателя на функцию
Оверхед не большой, к тому же в С++ тоже можно свой компаратор передавать, вызов которого может быть еще медленней, чем вызов функции по указателю.
1
techpriest
 Аватар для Mirmik
634 / 213 / 57
Регистрация: 27.02.2014
Сообщений: 1,180
04.04.2017, 12:58
А еще qsort использует побайтовое копирование вместо вызова конструкторов... что естественно.
1
 Аватар для avgoor
1550 / 877 / 179
Регистрация: 05.12.2015
Сообщений: 2,555
04.04.2017, 17:50
Цитата Сообщение от Kastaneda Посмотреть сообщение
Оверхед не большой
"Фишка" быстрой сортировки в том, что внутренний цикл очень маленький, чем он меньше - тем лучше. Поэтому во всех реализациях обмены происходят даже для равных элементов. Это получается быстрее, т.к. не нужно дополнительного условия на "скрещивание" указателей. Поэтому дополнительный вызов функции во внутреннем цикле сильно просаживает производительность.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.04.2017, 17:50
Помогаю со студенческими работами здесь

Напишите пожалуста коментарии к программе, т.е. что каждая функция означает?
Напишите пожалуста коментарии к программе, т.е. что каждая функция означает? Программа звучит так "Цифры даннго трехзначного числа N...

Поясните пожалуйста что означает двоеточие и то что идет после него
В 4 строчке после параметра в скобочках нету ";" или же тела функции, что не сходится с моим шаблоном в голове. Поясните пожалуйста что...

Что означает, что определение метода находится внутри определения класса?
Что означает, что определение метода находится внутри определения класса? Prostokat p0("Prostokat",2,3); cout <<...

Что означает запись в скобках и что возвращает return
Всем привет! Начал читать книгу BecomeAnXcoder и тут появился вопрос. В пример приведен такой код circleArea(float theRadius) //(1) ...

Что такое #, include, что это означает
______


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита, которое может. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа разработанного в конфигурации КА2. В качестве источника данных указан регистр накопления, в который записываются данные о. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru