Considérez la fonction intégrée suivante:
// Inline specifier version
#include<iostream>
#include<cstdlib>
inline int f(const int x);
inline int f(const int x)
{
return 2*x;
}
int main(int argc, char* argv[])
{
return f(std::atoi(argv[1]));
}
et la version équivalente de constexpr:
// Constexpr specifier version
#include<iostream>
#include<cstdlib>
constexpr int f(const int x);
constexpr int f(const int x)
{
return 2*x;
}
int main(int argc, char* argv[])
{
return f(std::atoi(argv[1]));
}
Ma question est la suivante: le constexprspécificateur implique-t-il le inlinespécificateur dans le sens où si un argument non constant est passé à une constexprfonction, le compilateur essaiera inlinela fonction comme si le inlinespécificateur était placé dans sa déclaration?
La norme C ++ 11 garantit-elle cela?
inlineprescripteur n'a plus rien à voir avec l' inlining
inlineest directement liée à l'inlining. Donc non, le constexprspécificateur n'implique pas le inlinespécificateur dans ce sens, car ce sens n'existe pas.
inlinespécificateur. (Ou peut-être que j'ai mal compris votre formulation.)