Yaptığım bazı çok karmaşık nesneler için temel aritmetik işlemcileri aşırı yüklemem gerekiyor. Şimdiye kadar, başarılı bir şekilde operator*
; Şimdi operator+
, vb gerekir. operator*
için kod çok büyük, ancak operator*
ve operator+
arasındaki tek fark, bazı karmaşık sayılar üzerinde *
yerine *
kullanıyorum bir satır olacaktır. Bu çizgi birçok kez çağrılan bir döngünün içinde olacaktır, bu yüzden etkin olmasını istiyorum, ki bu hiçbir işlev göstericisini ima eder. (Yanılıyorsam düzeltin.)Operatörü, işlev şablon parametresi olarak değiştir
Bu şablonlar için mükemmel bir kullanım gibi gözüküyor. Ama doğru sözdizimi konusunda bir kayıp yaşıyorum. Ben ComplicatedObject
sınıf tanımı içinde böyle bir şey düşünüyorum:
template <typename ComplexBinaryOp>
ComplicatedObject BinaryOp(const ComplicatedObject& B) const {
// Do lots of stuff
for(unsigned int i=0; i<OneBazillion; ++i) {
// Here, the f[i] are std::complex<double>'s:
C.f[i] = ComplexBinaryOp(f[i], B.f[i]);
}
// Do some more stuff
return C;
}
inline ComplicatedObject operator*(const ComplicatedObject& B) const {
return BinaryOp<std::complex::operator*>(B);
}
inline ComplicatedObject operator+(const ComplicatedObject& B) const {
return BinaryOp<std::complex::operator+>(B);
}
Bu soru ilgilidir: "function passed as template argument". Ancak şablon argümanları olarak iletilen işlevler operatör değildir.
Düşünebildiğim her şekilde sözdizimi ile uğraştım, ancak derleyici her zaman hatalı sözdizimden şikayetçidir. Bunu nasıl yapmalıyım?
Düzenleme:
Anlaşılır olması için, insanların ihtiyaç duyabileceği genellemeler ile birlikte yukarıda kodumu açısından tam bir çözüm içerir:
template <typename ComplexBinaryOp>
ComplicatedObject BinaryOp(const ComplicatedObject& B) const {
// Do lots of stuff
for(unsigned int i=0; i<OneBazillion; ++i) {
// Here, the f[i] are std::complex<double>'s:
C.f[i] = ComplexBinaryOp()(f[i], B.f[i]); // Note extra()'s
}
// Do some more stuff
return C;
}
inline ComplicatedObject operator+(const ComplicatedObject& B) const {
return BinaryOp<std::plus<std::complex<double> > >(B);
}
inline ComplicatedObject operator-(const ComplicatedObject& B) const {
return BinaryOp<std::minus<std::complex<double> > >(B);
}
inline ComplicatedObject operator*(const ComplicatedObject& B) const {
return BinaryOp<std::multiplies<std::complex<double> > >(B);
}
inline ComplicatedObject operator/(const ComplicatedObject& B) const {
return BinaryOp<std::divides<std::complex<double> > >(B);
}
'std :: complex' bir sınıf şablonu, yani std :: complex'. Ancak o zaman bile, ' :: operator * 've karmaşık :: operator +' karmaşık * üye işlevleri * vardır. Çalıştırmak için ' 'karmaşık bir örneği olmadan bunları yalnızca geçiremezsiniz. –
Praetorian
Aldığınız hata mesajları. İlginç soru için –
+1. Ayrıca bu soruyu - [C++ operatörler için işaretçiler] (http://stackoverflow.com/questions/4176895/c-pointers-to-operators) ilgili ve ilginç buldum. – keelar