C++のis_lvalue_referenceテンプレート
この記事では、C++STLでのstd::is_lvalue_referenceテンプレートの動作、構文、および例について説明します。
C ++のis_lvalue_referenceテンプレートは、定義された型が左辺値参照であるかどうかを確認するために使用されます。
左辺値とは何ですか?
左辺値は、代入演算子の左側にある値です。左辺値は、メモリの場所を参照する式です。
左辺値参照とは何ですか?
左辺値参照は、左辺値にバインドする参照です。これは、従来のC ++またはC言語で変数を参照する方法と非常によく似ています。つまり、変数自体にアンパサンド記号(&)を使用して、そのアドレスを参照します。
例
int& a;
構文
template <class T> is_lvalue_reference;
パラメータ
テンプレートにはタイプTのパラメーターのみを含めることができ、指定されたタイプが左辺値参照であるかどうかを確認します
戻り値
ブール値を返します。指定された値が左辺値参照の場合はtrue、指定された値が左辺値参照でない場合、または不明な場所を参照している場合はfalse
例
Input: is_lvalue<int &>::value; Output: True Input: is_lvalue<int>::value; Output: False
例
#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_lvalue_reference<TP>::value; cout << "\nTP& : "<< is_lvalue_reference<TP&>::value; cout << "\nTP&&: "<< is_lvalue_reference<TP&&>::value; return 0; }
出力
上記のコードを実行すると、次の出力が生成されます-
Checking for is_lvalue_reference: TP class : false TP& : true TP&&: false
例
#include <iostream> #include <type_traits> using namespace std; int main() { cout << std::boolalpha; cout << "Checking for is_lvalue_reference: "; cout << "\nint : "<<is_lvalue_reference<int>::value; cout << "\nint& : "<< is_lvalue_reference<int&>::value; cout << "\nint&&: "<< is_lvalue_reference<int&&>::value; cout << "\nchar : "<<is_lvalue_reference<char>::value; cout << "\nchar& : "<< is_lvalue_reference<char&>::value; cout << "\nchar&&: "<< is_lvalue_reference<char&&>::value; cout << "\nfloat : "<<is_lvalue_reference<float>::value; cout << "\nfloat& : "<< is_lvalue_reference<float&>::value; cout << "\nfloat&&: "<< is_lvalue_reference<float&&>::value; cout << "\ndouble : "<<is_lvalue_reference<double>::value; cout << "\ndouble& : "<< is_lvalue_reference<double&>::value; cout << "\ndouble&&: "<< is_lvalue_reference<double&&>::value; return 0; }
出力
上記のコードを実行すると、次の出力が生成されます-
Checking for is_lvalue_reference: int : false int& : true int&&: false char : false char& : true char&&: false float : false float& : true float&&: false double: false double : true double&&: falseの確認
-
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()の例です