Varsayılan işlev şablonları için şablon değişkenleri
Neden bir sınıf şablonu varsayılan şablon bağımsız değişkenleri yalnızca izin verilir? Neden üye işlevi bir şablon olarak varsayılan bir tür tanımlayabilir mi? Örneğin:
struct mycclass {
template<class T=int>
void mymember(T* vec) {
// ...
}
};
Bunun yerine, C varsayılan şablon bağımsız değişkenleri yalnızca bir sınıf şablonu izin verilen zorlar.
CEVAP
Mantıklı varsayılan şablon argümanlar vermek için yapar. Örneğin bir sıralama işlevi oluşturabilirsiniz:
template<typename Iterator,
typename Comp = std::less<
typename std::iterator_traits<Iterator>::value_type> >
void sort(Iterator beg, Iterator end, Comp c = Comp()) {
...
}
C 0 C tanıtır . Bjarne Stroustrup tarafından bu kusur raporu: ne dedi Default Template Arguments for Function Templates
Yasağı varsayılan şablon bağımsız değişken işlev şablonları bir gayri meşru kalan süre yerde duran işlevleri vardı tedavi olarak ikinci sınıf vatandaş ve gerekli tüm şablon bağımsız değişkenleri için çıkarılabilir dan bağımsız değişken yerine belirtildi.
Kısıtlama cidden gereksiz yere duran üye fonksiyonları fonksiyonları farklı yaparak programlama tarzı, böylece zor STL-tarzı kod yazma yapmak krampları.
JavaScript bir işlev için varsayılan p...
Nasıl benim bir işlev için tüm değişke...
Nasıl Clojure içinde işlev bağımsız de...
Bash ile şablonları yapılandırma dosya...
Fonksiyon değişkenleri tanımlamak için...