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

C++のstatic_assert


static_assertは、プログラマーがプログラムのコンパイル後に出力をあまり混乱させることなく画面にエラーを出力するのに役立つ関数です。

以前のC++11とC++14では、static_assertの機能が異なっていたため、static_assertを定義するときに独自のメッセージを作成する必要がありました。ただし、C ++ 17では、メッセージを渡さずにstatic_assertを呼び出すことができます。

BOOST_STATIC_ASSERTなどの他のassertライブラリ関数とも互換性があります。

構文

{
   auto __range= For-range-Intializer;
   auto __begin= begin-expression;
   auto __end= end-expression;
   for(; __begin!= __end; ++__begin){
      range-declaration= *__begin;
      statement
   }
}

__beginと__endのタイプは異なります。比較演算子のみが必要です。この変更は、既存のforループには影響しませんが、ライブラリにより多くのオプションを提供します。たとえば、この小さな変更により、範囲TS(およびC ++ 20の範囲)が範囲ベースのforループで機能できるようになります。

C++11の範囲ベースのfor ループ-

for (for-range-declaration : for-range-initializer){
   statement;
}

C ++ 14標準では、このようなループ式は次のコードと同等でした-

{
   auto __range = for-initializer;
   for ( auto __begin= begin-expresson, __end = end-expression; __begin != __end; ++__begin ){
      for-range-declaration = *__begin;
         statement
   }
}

#include <bits/stdc++.h>
using namespace std;
template <typename T, size_t n, typename F> //Template Declaration
void fillarray (array<T, N> & a, F && f) //Function to store the values{
   static_assert(is_convertible<typename result_of<F()>::type, T>::value,"Incompatible type returned by fun()"); //static_assert signature to ommit the errors.
   for (auto x : a)
      x = f();
}
int main (){
   array<vector<string>, 20> a;
   fillarray(a, []() { return vector<string>{"TutorialsPoint"}; });
   return 0;
}

出力

…
…
…
prog.cpp:20:61: required from here
prog.cpp:10:5: error: static assertion failed:
Incompatible type returned by fun()

  1. C++での質素な数

    この問題では、正の整数Nが与えられます。私たちのタスクは、与えられた数が質素な数であるかどうかをチェックするプログラムを作成することです。 不正な番号 −指定された数の素因数分解の桁数よりも厳密に桁数が多い数。 例 − 625、数625の素因数は5 4です。 。 625の桁数は3です。 5 4の桁数 は2です。 3は厳密に2より大きくなります。したがって、625は質素な数です。 最初のいくつかの質素な数は − 125、128、243、256、343、512、625など。 問題を理解するために例を見てみましょう Input: n = 128 Output: Frugal n

  2. C++五胞体数

    五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと