名前空間
変種
操作

std::pointer_traits

提供: cppreference.com
< cpp‎ | memory
 
 
ユーティリティライブラリ
汎用ユーティリティ
日付と時間
関数オブジェクト
書式化ライブラリ(C++20)
(C++11)
関係演算子 (C++20で非推奨)
整数比較関数
(C++20)
スワップと型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
一般的な語彙の型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等文字列変換
(C++17)
(C++17)
 
動的メモリ管理
未初期化記憶域
ガベージコレクションサポート
その他
pointer_traits
(C++11)
(C++20)
(C++11)
(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 クラステンプレートはポインタライクな型 (boost::interprocess::offset_ptr などのファンシーポインタ) のいくつかの性質にアクセスする標準的な方法を提供します。 標準のテンプレート std::allocator_traitsAllocator によって要求される様々な typedef のためのデフォルトを決定するために pointer_traits に頼っています。

1) 特殊化されていない pointer_traits は以下の型を宣言します。

目次

[編集]メンバ型

定義
pointerPtr
element_type 存在すれば Ptr::element_type、そうでなく Ptr がテンプレート Template<T, Args...> の実体化であれば T
difference_type 存在すれば Ptr::difference_type、そうでなければ std::ptrdiff_t

[編集]メンバエイリアステンプレート

テンプレート 定義
template <class U> using rebind 存在すれば Ptr::rebind<U>、そうでなく Ptr がテンプレート Template<T, Args...> の実体化であれば Template<U, Args...>

[編集]メンバ関数

[静的]
引数を指す逆参照可能なポインタを取得します
(パブリック静的メンバ関数)[edit]

2) 以下の型を宣言する、ポインタ型 T* に対する特殊化が提供されます。

[編集]メンバ型

定義
pointerT*
element_typeT
difference_typestd::ptrdiff_t

[編集]メンバエイリアステンプレート

テンプレート 定義
template< class U > using rebind U*

[編集]メンバ関数

[静的]
引数を指す逆参照可能なポインタを取得します
(パブリック静的メンバ関数)[edit]

3) ユーザ定義のファンシーポインタ型に対する特殊化は追加の静的メンバ関数を定義しても構いません。

[編集]オプショナルなメンバ関数

[静的](C++20)
ファンシーポインタから生のポインタを取得します (pointer_to の逆)
(パブリック静的メンバ関数)[edit]

[編集]ノート

rebind メンバテンプレートエイリアスは、 T を指すポインタライクな型が与えられたときに、 U を指す同じポインタライクな型を取得することを可能とします。 例えば、

using another_pointer = std::pointer_traits<std::shared_ptr<int>>::rebind<double>; static_assert(std::is_same<another_pointer, std::shared_ptr<double>>::value);

[編集]

#include <memory>#include <iostream>   template<class Ptr>struct BlockList {// メモリブロックの事前定義。struct block;   // ポインタライクなオブジェクト Ptr s からメモリブロックへのポインタを定義します。// Ptr が任意の種類の T* の場合、 block_ptr_t は block* です。// Ptr が smart_ptr<T> の場合、 block_ptr_t は smart_ptr<block> です。using block_ptr_t =typename std::pointer_traits<Ptr>::template rebind<block>;   struct block {std::size_t size; block_ptr_t next_block;};   block_ptr_t free_blocks;};   int main(){ BlockList<int*> bl1;// bl1.free_blocks の型は block* です。   BlockList<std::shared_ptr<char>> bl2;// bl2.free_blocks の型は std::shared_ptr<block> です。std::cout<< bl2.free_blocks.use_count()<<'\n';}

出力:

​0​

[編集]関連項目

アロケータ型に関する情報を提供します
(クラステンプレート)[edit]
(C++11)
& 演算子がオーバーロードされている場合でも、オブジェクトの実際のアドレスを取得します
(関数テンプレート)[edit]
close