呼び出しを行わずに関数を探索する: 謎を解く
次を想像してください: かっこを使用して関数を呼び出す代わりに、コーディングを行っています。その名前を印刷するだけです。驚くべきことに、結果は常に 1 です。この型破りなアプローチでは、1 についても、期待される関数ポインターが存在しないことについても、困惑することになります。
コードの複雑さを掘り下げてみましょう:
#include
using namespace std;
void pr()
{
cout 意図に反して、実際には cout
理解を深めるために、印刷する前に cout
C 11 は次のような洗練されたソリューションを提供します。
template
std::ostream & operatorこのオーバーロードを使用すると、任意の引数の関数ポインターを出力し、関数ポインターのアドレスや引数の数などの情報を表示できます。
これで、謎の 1 は次のとおりです。これは単なる偶然ではなく、暗黙的な型変換の結果です。この動作を理解することは、予期しない結果を回避し、より堅牢なコードを作成するために重要です。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3