Skip to content

Latest commit

 

History

History
175 lines (130 loc) · 9.05 KB

class_template_page.md

File metadata and controls

175 lines (130 loc) · 9.05 KB

page_title (1行目の見出し1はページのタイトルです。修飾なしで記載してください)

(cpprefjpを編集するには および cpprefjpでのMarkdown記法の制限と拡張 を先に読んで下さい。)

( サンプルコードは文章中のどの部分で書いても大丈夫です。閲覧者の理解を助けるために必要だと感じたところで入れてください。 その際拡張構文であるexampleタグをルールに従って付け、コンパイル・実行可能にすることを検討してください。 )

  • header_name[meta header]
  • class[meta id-type]
  • std[meta namespace]
  • cpp17[meta cpp]
namespace std {
  class definition; // クラスの宣言を記述します。
}

概要

(ここには、クラスの概要を記述します。必須事項です。)

(必要な項目を省略する場合には、「(執筆中)」と書いておいてください。)

テンプレートパラメータ制約

(ここには、クラスのテンプレートパラメータに対する制約を記載します。SFINAE-friendlyな関数の条件、制約テンプレートによる条件などを記載します。)

適格要件

(ここには、満たさなければプログラムが不適格となる要件を記載します。static_assertに相当します。規格ではMandatesの項目です。)

この機能が必要になった背景・経緯

(ここには、その機能が必要になった背景や経緯を記述します。その機能で解決したい問題は何だったのかは、ユーザーがその言語機能を実際に使う上で重要な情報となります。余裕があったら書いてください)

メンバ関数

構築・破棄

名前 説明 対応バージョン
(constructor) コンストラクタ
(destructor) デストラクタ
operator= 代入演算子
function_name 説明

静的メンバ関数

名前 説明 対応バージョン

メンバ型

名前 説明 対応バージョン

非メンバ関数

名前 説明 対応バージョン

比較演算子

(比較演算子がデフォルト定義され、個別ページを作らない場合の記述例。オペランドの組み合わせ数が多い場合には、個別ページを作ることを推奨する)

名前 説明 対応バージョン
bool operator==(const X&, const X&) = default; 等値比較
bool operator!=(const X&, const X&); 非等値比較 (==により使用可能)
strong_ordering operator<=>(const X&, const X&) = default; 三方比較
bool operator<(const X&, const X&); 左辺が右辺より小さいかを判定する (<=>により使用可能)
bool operator<=(const X&, const X&); 左辺が右辺以下を判定する (<=>により使用可能)
bool operator>(const X&, const X&); 左辺が右辺より大きいかを判定する (<=>により使用可能)
bool operator>=(const X&, const X&); 左辺が右辺以上かを判定する (<=>により使用可能)

非メンバ(Hidden friends)関数

(friend付きメンバ関数はこの見出し以下で記載する。counted_iteratorを例として参照)

名前 説明 対応バージョン
swap 2つのオブジェクトを入れ替える

// (ここには、クラスを解説するための、サンプルコードを記述します。)
// (インクルードとmain()関数を含む、実行可能なサンプルコードを記述してください。そのようなコードブロックにはexampleタグを付けます。)

#include <iostream>

int main()
{
  int variable = 0;
  std::cout << variable << std::endl;
}
  • variable[color ff0000]

(コードブロック中の識別子に、文字色を付ける例です。)

出力

0

(ここには、サンプルコードの実行結果を記述します。何も出力がない場合は、項目を削除せず、空の出力にしてください。)
(実行結果が処理系・実行環境によって異なる場合は、項目名を「出力例」に変更し、可能であればその理由も併記してください。)

バージョン

言語

  • C++11

処理系

  • Clang: 1.9 [mark verified], 2.9 [mark verified], 3.0 [mark verified], 3.1 [mark verified], 3.2 [mark verified], 3.3 [mark verified]
  • GCC: 4.3.6 [mark verified], 4.4.7 [mark verified], 4.5.3 [mark verified], 4.6.3 [mark verified], 4.7.2 [mark verified], 4.8.1 [mark verified]
  • ICC: 10.1 [mark verified], 11.0 [mark verified], 11.1 [mark verified], 12.0 [mark verified]
  • Visual C++: 2003 [mark verified], 2005 [mark verified], 2008 [mark verified], 2010 [mark verified], 2012 [mark verified]

(ここには、その機能が存在する言語のバージョンと、確認がとれたコンパイラとそのバージョンを記述します。)
(これらの項目を削除した場合、C++03のあらゆる環境で使用できることを意味します。)

関連項目

(ここには、その機能と関連のあるcpprefjpサイト内の項目へのリンクを記述します。とくに必要がないと判断した場合、項目を削除してください。)

参照

(ここには、その関数・変数・定数を理解するにあたっての参考資料や、関連する機能へのリンクを記述します。とくに必要がないと判断した場合、項目を削除してください。)