Selon la norme, vous n'avez pas de chance. Il n'y a aucun moyen d'initialiser un argument pointeur à quoi que ce soit en plus de l'adresse d'un global. §14.3.2/1:
A template-argument for a non-type, non-template template-parameter shall be one of:
- an integral constant-expression of integral or enumeration type; or
- the name of a non-type template-parameter; or
- the address of an object or function with external linkage, including function templates and function template-ids but excluding non-static class members, expressed as & id-expression where the & is optional if the name refers to a function or array, or if the corresponding template-parameter is a reference; or
- a pointer to member expressed as described in 5.3.1 .
§14.3.2/5:
- for a non-type template-parameter of type pointer to object, qualification conversions (4.4) and the array-to-pointer conversion (4.2) are applied. [Note: In particular, neither the null pointer conversion (4.10) nor the derived-to-base conversion (4.10) are applied. Although 0 is a valid template-argument for a non-type template-parameter of integral type, it is not a valid template-argument for a non-type template-parameter of pointer type. ]
Cependant, Comeau accepte cette solution de contournement invalide:
typedef Tem<FILE*, (FILE *) NULL > TemFile;
Ce code a une mince chance de conformité: je ne peux pas trouver où la norme dit spécifiquement qu'une expression par défaut est utilisée verbatim à la place d'un argument manquant, et je ne peux pas trouver un défaut connu correspondant. Quelqu'un at-il une référence?
#include <stdio.h>
template <typename T, T *v = (T*) 0> class Tem
{
T t;
Tem()
{
t = v;
}
};
typedef Tem<FILE> TemFile;
Pour plus de portabilité, vous pourriez envisager de créer un FILE FILE_NULL;
faux, passer &FILE_NULL
et test pour pointer-égalité avec celle au lieu de zéro.
Pour ce que ça vaut, utilisez la liste d'initialisation pour initialiser les membres: 'Tem(): t (v) {}' – GManNickG
Hmm, le code ressemble à "vanilla" C++. Je pensais que l'objectif C++ ressemblait à "[trucs ici] scary-tokens là-bas". Ou était-ce objectif-C oO –
Ne peut pas croire que c'est une extension propriétaire de Microsoft. Les paramètres de modèle d'entier sont-ils également interdits? –