Как использовать функцию-член с std::bsearch
У меня есть класс C++, но я также использую какой-то низкий уровень C, и мне нужно использовать bsearch
функция. Последний аргумент bsearch
является функцией сравнения, и я хочу реализовать указанную функцию таким образом, чтобы она могла получить доступ к закрытым переменным const класса.
Проблема в том, что если я сделаю функцию сравнения функцией-членом, она не будет работать, потому что она не будет преобразована в обычный указатель функции. Если я сделаю функцию, не являющуюся членом, я могу передать это bsearch
, но не сможет получить доступ к закрытым переменным класса.
Что делать?
3 означает, что есть 3 элемента.16,32,56 - это смещенные байты. Мне нужен bsearch для поиска акторов. Я ищу в массиве смещений. Мне нужна функция сравнения, которая бы сравнивала актеров, но мне также нужно const void * actorFile указатель для вычисления местоположения в функции сравнения.actorFIle является закрытой переменной класса.
2 ответа
Решение состоит в том, чтобы отказаться от функции библиотеки C и использовать C++ в том виде, в котором он предназначен. Стандартная библиотека C++ также имеет функцию поиска утилиты, она называется std::lower_bound
, И он принимает общие функционально-подобные объекты, а не только обычные указатели функций.
Это позволяет вам вызывать его с помощью лямбда-выражения, которое захватывает ваш класс:
std::lower_bound(start, finish, value, [this] (auto const& lhs, auto const& rhs) {
/* Compare and utilize anything this can point to*/ });
Если вы действительно привязаны к bsearch
просто используйте вашу функцию-член внутри функции, не являющейся членом. Следовательно, вам не нужен доступ к частным пользователям.
/* Create global variable to use in compare proc*/
actors_data_base* cmp_data_base = NULL;
/* Write compare routine like */
int cmp_proc(const void * a, const void * b)
{
size_t a_offset = static_cast<size_t>(a);
size_t b_offset = static_cast<size_t>(b);
return cmp_data_base->compare_actors(a_offset, b_offset);
}
/* Set global pointer and use bsearch */
actors_data_base = &my_data_base;
bsearch(&my_value, array, size, sizeof(size_t), cmp_proc);
Определенно, это ужасно из-за использования глобальной переменной. Но это единственный способ передать контекст для сравнения процедур. Вы можете подумать об использовании локального хранилища потоков, чтобы избежать проблем с потоками (cmp_proc
не должен использоваться одновременно из-за глобальной переменной)
Следовательно, вы бы гораздо лучше использовать std::lower_bound
,