C++のis_rvalue_referenceテンプレート
この記事では、C++STLでのstd::is_rvalue_referenceテンプレートの動作、構文、および例について説明します。 C ++のis_rvalue_referenceテンプレートは、定義された型が右辺値参照であるかどうかを確認するために使用されます。
右辺値とは何ですか?
右辺値は、代入演算子の右側にある値です。右辺値は値です
右辺値参照とは何ですか?
右辺値の参照は、二重アンパサンド記号(&&)で識別されます。これは、右辺値のみで初期化するために使用されます。
構文
int&& a;
構文
template <class T> is_rvalue_reference;
パラメータ
テンプレートにはタイプTのパラメーターのみを含めることができ、指定されたタイプが右辺値参照であるかどうかを確認します
戻り値
ブール値を返します。指定された値が右辺値参照である場合はtrue、指定された値が右辺値参照ではない場合、または不明な場所を参照している場合はfalseです。
例
Input: is_rvalue<int&>::value; Output: False Input: is_rvalue<int&&>::value; Output: True
例
#include <iostream> #include <type_traits> using namespace std; int main() { cout << std::boolalpha; cout << "Checking for is_lvalue_reference: "; cout << "\nint : "<<is_rvalue_reference<int>::value; cout << "\nint& : "<< is_rvalue_reference<int&>::value; cout << "\nint&&: "<< is_rvalue_reference<int&&>::value; cout << "\nchar : "<<is_rvalue_reference<char>::value; cout << "\nchar& : "<< is_rvalue_reference<char&>::value; cout << "\nchar&&: "<< is_rvalue_reference<char&&>::value; cout << "\nfloat : "<<is_rvalue_reference<float>::value; cout << "\nfloat& : "<< is_rvalue_reference<float&>::value; cout << "\nfloat&&: "<< is_rvalue_reference<float&&>::value; cout << "\ndouble : "<<is_rvalue_reference<double>::value; cout << "\ndouble& : "<< is_rvalue_reference<double&>::value; cout << "\ndouble&&: "<< is_rvalue_reference<double&&>::value; return 0; }
出力
上記のコードを実行すると、次の出力が生成されます-
Checking for is_rvalue_reference: int : false int& : false int&&: ture char : false char& : false char&&: ture float : false float& : false float&&: ture double: false double : false double&&: tureの確認
例
#include <iostream> #include <type_traits> using namespace std; class TP { }; int main() { cout << std::boolalpha; cout << "Checking for is_lvalue_reference: "; cout << "\nTP class : "<<is_rvalue_reference<TP>::value; cout << "\nTP& : "<< is_rvalue_reference<TP&>::value; cout << "\nTP&&: "<< is_rvalue_reference<TP&&>::value; return 0; }
出力
上記のコードを実行すると、次の出力が生成されます-
Checking for is_rvalue_reference: TP class : false TP& : false TP&&: true
-
C ++のexpm1()
関数expm1()は、任意の数から1を引いた累乗の指数を計算するために使用されます。 (指数をaの累乗で累乗した)-1の値を返します。 expm1()の数式は次のとおりです。 expm1(a) = (e^a) - 1 C ++言語でのexpm1()の構文は次のとおりです。 float expm1(variable_name); ここで 変数名 −値が計算される変数に付けられた任意の名前。 これは、C ++言語でのexpm1()の例です。 例 #include <iostream> #include <cmath> using namespace std
-
C ++のlog1p()
関数log1p()は、(a + 1)の自然対数(基数e対数)を計算するために使用されます。ここで、aは任意の数値です。 (a + 1)の自然対数の値を返します。 -1未満の値を渡すと、Not a number(Nan)が返されます。 log1p()の数式は次のとおりです。 log1p(a) = base-e log(a+1) C ++言語でのlog1p()の構文は次のとおりです。 float log1p(float variable_name); ここで variable_name −対数値が計算される変数に付けられた名前。 これは、C ++言語でのlog1p()の例です