Пространства имён
Варианты
Действия

std::pointer_traits

Материал из cppreference.com
< cpp‎ | memory

 
 
 
Динамическое управление памятью
Низкоуровневое управление памятью
Аллокаторы
allocator
allocator_traits(C++11)
allocator_arg_t(C++11)
allocator_arg(C++11)
uses_allocator(C++11)
scoped_allocator_adaptor(C++11)
Неинициализированные хранилища
uninitialized_copy
uninitialized_copy_n(C++11)
uninitialized_fill
uninitialized_fill_n
raw_storage_iterator
get_temporary_buffer
return_temporary_buffer
Умные указатели
unique_ptr(C++11)
shared_ptr(C++11)
weak_ptr(C++11)
auto_ptr(устарело)
owner_less(C++11)
enable_shared_from_this(C++11)
bad_weak_ptr(C++11)
default_delete(C++11)
Поддержка сборки мусора
declare_reachable(C++11)
undeclare_reachable(C++11)
declare_no_pointers(C++11)
undeclare_no_pointers(C++11)
pointer_safety(C++11)
get_pointer_safety(C++11)
Разное
pointer_traits(C++11)
addressof(C++11)
align(C++11)
Библиотека C
 
Определено в заголовочном файле <memory>
template< class Ptr > struct pointer_traits;
(1) (начиная с C++11)
template< class T > struct pointer_traits<T*>;
(2) (начиная с C++11)
Шаблон pointer_traits класс предоставляет стандартный способ доступа к определенным свойствам указатель, как типа. Стандартный шаблон std::allocator_traits опирается на pointer_traits для определения значения по умолчанию для различных определений типов требует от Allocator.
Оригинал:
The pointer_traits class template provides the standardized way to access certain properties of pointer-like types. The standard template std::allocator_traits relies on pointer_traits to determine the defaults for various typedefs requires by Allocator.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
1)
Неспециализированных pointer_traits заявляет следующих типов:
Оригинал:
The non-specialized pointer_traits declares the following types:
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Содержание

[править] Типы-члены

Тип Definition
pointer Ptr
element_type
Ptr::element_type если он присутствует. В противном случае, если T Ptr является Template<T, Args...> шаблона
Оригинал:
Ptr::element_type if present. Otherwise T if Ptr is a template instantiation Template<T, Args...>
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
difference_type
Ptr::difference_type если он присутствует, иначе std::ptrdiff_t
Оригинал:
Ptr::difference_type if present, otherwise std::ptrdiff_t
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

[править] Член псевдоним шаблонов

Шаблон
Оригинал:
Template
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Definition
template <class U> using rebind
Ptr::rebind<U> если существует, в противном случае, если Tempate<U, Args...> Ptr является Template<T, Args...> шаблона
Оригинал:
Ptr::rebind<U> if exists, otherwise Tempate<U, Args...> if Ptr is a template instantiation Template<T, Args...>
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

[править] Функции-члены

[static]
получает dereferencable указатель на аргумент
Оригинал:
obtains a dereferencable pointer to its argument
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public static функция-член)
2)
Специализация предназначена для типов указателей, T*, который объявляет следующие типы
Оригинал:
A specialization is provided for pointer types, T*, which declares the following types
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

[править] Типы-члены

Тип Definition
pointer T*
element_type T
difference_type std::ptrdiff_t

[править] Член псевдоним шаблонов

Шаблон
Оригинал:
Template
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Definition
template< class U > using rebind U*

[править] Функции-члены

[static]
получает dereferencable указатель на аргумент}
Оригинал:
obtains a dereferencable pointer to its argument}
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public static функция-член)

[править] Notes

Перепривязывают псевдоним шаблон члена позволяет, учитывая указатель, как типа, который указывает на T, чтобы получить тот же указатель, как типа, который указывает на U. Так, например,
Оригинал:
The rebind member template alias makes it possible, given a pointer-like type that points to T, to obtain the same pointer-like type that points to U. For example,
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

std::is_same<std::pointer_traits< std::shared_ptr<int>>::rebind<double>, std::unique_ptr<double> >::value), "")

[править] Пример

#include <memory>
#include <iostream>
 
template <class Ptr>
struct BlockList
{
   // Predefine a memory block
   struct block;
 
   // Define a pointer to a memory block from the kind of pointer Ptr s
   // If Ptr is any kind of T*, block_ptr_t is block*
   // If Ptr is smart_ptr<T>, block_ptr_t is smart_ptr<block>
   typedef typename std::pointer_traits<Ptr>::template rebind<block> block_ptr_t;
 
   struct block
   {
      std::size_t size;
      block_ptr_t next_block;
   };
 
   block_ptr_t free_blocks;
};
 
int main()
{
    BlockList<int*> bl1;
    // The type of bl1.free_blocks is block*
 
    BlockList<std::shared_ptr<char>> bl2;
    // The type of bl2.free_blocks is std::shared_ptr<block>
    std::cout << bl2.free_blocks.use_count() << '\n';
}

Вывод:

​0​

[править] См. также

предоставляет информацию о распределитель типа
Оригинал:
provides information about allocator types
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(шаблон класса) [edit]
(C++11)
получает фактический адрес объекта, даже если и оператор перегружен
Оригинал:
obtains actual address of an object, even if the & operator is overloaded
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(шаблон функции) [edit]