std::basic_ios
a un constructeur public :
explicit basic_ios (std::basic_streambuf<CharT,Traits>* sb);
OMI, la seule raison pour laquelle une classe a un constructeur public est d'utiliser une instance autonome de cette classe dans un programme. Si une classe existe uniquement pour que d'autres classes en descendent (comme cela semble être le cas pour basic_ios
), tous les constructeurs de la classe devraient l'être protected
. Les constructeurs de std::ios_base
sont tous protégés. Mais, pour une raison quelconque, les concepteurs de la norme ont fait de ce constructeur un basic_ios
public.
basic_ios
est utilisé comme classe de base pour plusieurs types de flux, et je ne peux pas imaginer un cas d'utilisation où vous en auriez un qui n'était pas au moins un basic_istream
ou basic_ostream
. Est-ce qu'il y a un?
basic_ios
ctor prenant unbasic_streambuf*
a été public depuis avant que vous ne puissiez le faireusing B::B;
. Je m'attends à ce que les anciennes implémentations aient juste un proxy ctor:A(int x) : B(x) {}
- qui fonctionne bien même siB
ctor l'estprotected
.Ce que je n'ai pas remarqué, c'est que
std::basic_istream
,std::basic_ostream
et ilstd::basic_iostream
y avait aussi des constructeurs publics (chacun prend unstd::basic_streambuf*
).Cela permet un analogue de programmation générique du polymorphisme, dans la même veine que l'idiome pimpl.
Autrement dit, de cette façon, vous pouvez créer un type streambuf spécialisé et l'utiliser dans un
basic_
[io]stream
sans avoir à créer des classes de flux spécialisées. (La fonctionnalité est limitée: vous ne pouvez pas affecter un nouveau tampon au même flux, et vous devez garder une trace externe de la durée de vie et de la propriété du tampon).Les
basic_
[io]fstream
etbasic_
[io] spécialisésstringstream
contiennent chacun une instance complète du type de tampon associé. Cela signifie qu'une instance d'un type de flux spécialisé ne fonctionnera qu'avec son tampon interne et pas une autre, pas même une du même type. L'utilisation d'unbasic_
[io] brutstream
est une solution de contournement (maladroite) à cela.la source