Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
Разработка программного обеспечения

Class template bs_set_base_hook

Boost , The Boost C++ Libraries BoostBook Documentation Subset , Reference

Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

PrevUpHomeNext

Class template bs_set_base_hook

boost::intrusive::bs_set_base_hook

Synopsis

// In header: <boost/intrusive/bs_set_hook.hpp>
template<class... Options> 
class bs_set_base_hook : public make_bs_set_base_hook::type< O1, O2, O3 > {
public:
  // construct/copy/destruct
  bs_set_base_hook();
  bs_set_base_hook(const bs_set_base_hook &);
  bs_set_base_hook & operator=(const bs_set_base_hook &);
  ~bs_set_base_hook();
  // public member functions
  void swap_nodes(bs_set_base_hook &);
  bool is_linked() const;
  void unlink();
};

Description

Выберите класс изbs_set_base_hookдля хранения объектов в bs_set/bs_multiset.bs_set_base_hookсодержит данные, необходимые для поддержания bs_set/bs_multiset и предоставляет соответствующиеЦенностные чертыкласс для bs_set/bs_multiset.

Крючок допускает следующие варианты:<tag<>>,<void_pointer<>>,<link_mode<>>.

<tag<>>определяет тег для идентификации узла. Одно и то же значение тега может использоваться в разных классах, но если класс получен из более чем одного<list_base_hook>, то каждый<list_base_hook>нуждается в своем уникальном теге.

<void_pointer<>>- тип указателя, который будет использоваться внутри крючка и контейнера, сконфигурированного для использования этого крючка.

<link_mode<>>будет указывать режим соединения крючка<normal_link>,<auto_unlink>или<safe_link>.

bs_set_base_hook public construct/copy/destruct

  1. <
    bs_set_base_hook();
    >

    Эффекты: Если<link_mode><auto_unlink>или<safe_link>инициализирует узел в несвязанное состояние.

    Бросает: Ничего.

  2. <
    bs_set_base_hook(constbs_set_base_hook&);
    >

    Эффекты: Если<link_mode><auto_unlink>или<safe_link>инициализирует узел в несвязанное состояние. Аргумент игнорируется.

    Бросает: Ничего.

    Обоснование: Предоставление копи-конструктора делает занятия с помощью крючка STL-совместимыми, не заставляя пользователя выполнять какую-то дополнительную работу.<swap>может использоваться для эмуляции подвижной семантики.

  3. <
    bs_set_base_hook&operator=(constbs_set_base_hook&);
    >

    Эффекты: Пустая функция. Аргумент игнорируется.

    Бросает: Ничего.

    Обоснование: Предоставление оператора присваивания делает классы с использованием крючка STL-совместимыми, не заставляя пользователя выполнять некоторую дополнительную работу.<swap>может использоваться для эмуляции подвижной семантики.

  4. <
    ~bs_set_base_hook();
    >

    Эффекты: Если<link_mode><normal_link>, деструктор ничего не делает (т.е. код не генерируется). Если<link_mode><safe_link>и объект хранится в наборе, то высказывание возносится. Если<link_mode><auto_unlink>и<is_linked()>истинно, то узел несвязан.

    Бросок: Ничего.

bs_set_base_hook public member functions

  1. <
    voidswap_nodes(bs_set_base_hook&other);
    >

    Эффекты: Переключение двух узлов меняет положение элементов, связанных с этими узлами, в одном или двух контейнерах. То есть, если узел является частью элемента e1, узел x является частью элемента e2 и оба элемента включены в контейнеры s1 и s2, то после операции обмена e1 находится в s2 в положении e2, а e2 находится в s1 в положении e1. Если один элемент не находится в контейнере, то после операции обмена другой элемент не находится в контейнере. Итераторы e1 и e2, относящиеся к этим узлам, недействительны.

    Сложность: Постоянная

    Бросает: Ничего.

  2. <
    boolis_linked()const;
    >

    Предварительное условие:<link_mode>должно быть<safe_link>или<auto_unlink>.

    Возврат: истинно, если узел принадлежит контейнеру, ложно в противном случае. Эта функция может использоваться для проверки того, вернет ли<set::iterator_to>действительный итератор.

    Сложность: Постоянная

  3. <
    voidunlink();
    >

    Эффекты: Удаляет узел, если он вставлен в контейнер. Эта функция допускается только в том случае, если<link_mode>является<auto_unlink>.

    Бросок: Ничего.


PrevUpHomeNext

Статья Class template bs_set_base_hook раздела The Boost C++ Libraries BoostBook Documentation Subset Reference может быть полезна для разработчиков на c++ и boost.




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.



:: Главная :: Reference ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-30 11:47:00
2025-05-19 19:31:28/0.0090968608856201/1