Considere a seguinte função embutida:
// 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]));
}
e a versão equivalente 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]));
}
Minha pergunta é: o constexpr
especificador implica o inline
especificador no sentido de que se um argumento não constante for passado para uma constexpr
função, o compilador tentará inline
a função como se o inline
especificador tivesse sido colocado em sua declaração?
O padrão C ++ 11 garante isso?
inline
especificador não tem mais nada a ver com inlining
inline
está diretamente relacionada ao inlining. Portanto, não, o constexpr
especificador não implica o inline
especificador nesse sentido, pois esse sentido não existe.
inline
especificador faz. (Ou talvez eu não tenha entendido sua frase.)