Skip to content

Latest commit

 

History

History
85 lines (61 loc) · 1.82 KB

declval.md

File metadata and controls

85 lines (61 loc) · 1.82 KB

#declval

namespace std {
  template <class T>
  typename add_rvalue_reference<T>::type
    declval() noexcept; // as unevaluated operand
}

##概要 指定された型の値を得る。

この関数は、decltype(expr)noexcept(expr) といった、実際には評価されない式の内部において、特定の型を持った式を作るためのヘルパ関数である。

##戻り値 この関数は呼び出されないので、値としては何も返さない。

実際には評価されない文脈(decltype, sizeof, noexcept)で使用することで、指定された型に対する特定の演算が可能かどうかを調べるためだけの「型の値」が返る。

##例外 投げない

##備考 テンプレートパラメータTは、不完全型であってもよい。

この関数が実際に評価されうる場合、プログラムは不適格となる。

##例

#include <iostream>
#include <utility>

// この関数は、型Fromから型Toへの明示的な型変換が定義されている場合のみ
// オーバーロード解決の候補となる
template <class To, class From>
decltype(static_cast<To>(std::declval<From>())) convert(From&& x)
{
  return static_cast<To>(std::forward<From>(x));
}

// std::declval()は実際に評価してはいけない
/*
template <class T>
T f() { return std::declval<T>(); }

void g()
{
  int x = f<int>(); // エラー!
}
*/

int main()
{
  int x = 3;
  double d = convert<double>(x);

  std::cout << d << std::endl;
}
  • declval[color ff0000]

###出力

3

##バージョン ###言語

  • C++11

###処理系

##参照