C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++のis_pointerテンプレート


この記事では、C++STLでのstd::is_pointerテンプレートの動作、構文、および例について説明します。

is_ポインターは、ヘッダーファイルの下にあるテンプレートです。このテンプレートは、指定されたタイプTがポインタータイプであるかどうかを確認するために使用されます。

ポインタとは何ですか?

ポインタは非静的タイプであり、別のタイプのアドレスを保持します。つまり、メモリプール内のメモリ位置を指します。アスタリスク(*)を使用してポインタを定義し、ポインタが保持している特定のメモリを参照する場合は、アスタリスク(*)も使用します。

これらは、nullとして初期化でき、必要に応じて後でタイプを変更できるタイプです。

構文

template <class T> is_pod;

パラメータ

テンプレートにはタイプTのパラメーターのみを含めることができ、指定されたタイプがポインターであるかどうかを確認します。

戻り値

ブール値を返します。指定された型がポインタ変数の場合はtrue、指定された型がポインタでない場合はfalseです。

Input: is_pointer<int>::value;
Output: False

Input: is_pointer<int*>::value;
Output: True

#include <iostream>
#include <type_traits>
using namespace std;
class TP{
};
int main() {
   cout << boolalpha;
   cout << "checking for is_pointer:";
   cout << "\nTP: " << is_pointer<TP>::value;
   cout << "\nTP*: " << is_pointer<TP*>::value;
   cout << "\nTP&: " << is_pointer<TP&>::value;
   cout << "\nNull Pointer: "<< is_pointer<nullptr_t>::value;
   return 0;
}

出力

上記のコードを実行すると、次の出力が生成されます-

checking for is_pointer:
TP: false
TP*: true
TP&: false
Null Pointer: false

#include <iostream>
#include <type_traits>
using namespace std;
int main() {
   cout << boolalpha;
   cout << "checking for is_pointer:";
   cout << "\nint: " << is_pointer<int>::value;
   cout << "\nint*: " << is_pointer<int*>::value;
   cout << "\nint **: " << is_pointer<int **>::value;
   cout << "\nint ***: "<< is_pointer<int ***>::value;
   return 0;
}

出力

上記のコードを実行すると、次の出力が生成されます-

checking for is_pointer:
int: false
int*: true
Int **: true
Int ***: true

  1. 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

  2. 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()の例です