я написал следующий класс, который имеет условный член _s
и метод worksOnlyForString
, который обращается к члену как std::string
.если метод worksOnlyForString
не вызывается, код компилируется, даже если элемент не является std::string
.
существует хорошо известное правило c ++ - функция шаблона полностью компилируется только при использовании.Но в моем случае условный член вызывает такое поведение.
Вопрос в том, почему код компилируется.
#include <iostream>
#include <string>
#include <type_traits>
template<bool isString>
struct S
{
void worksAlways()
{
std::cout << _s;
}
// compiles for isString == false. (if not used)
// but why
void worksOnlyForString()
{
std::cout<<_s.size();
}
std::conditional_t<isString, std::string, int> _s;
#if 0
//this part does not compile and it is expected and ok
void checkUnconditionalMember()
{
std::cout<<_i.size();
}
int _i;
#endif
};
int main()
{
S<true> s;
s._s = "xxx";
s.worksOnlyForString(); // ok prints "3"
S<false> s1; // why does this line compile ?
s1._s = 99;
s1.worksAlways(); // ok prints "99"
return 0;
}