C++ - 模板函数须要类型转换时使用友元(friend)模板函数
生活随笔
收集整理的這篇文章主要介紹了
C++ - 模板函数须要类型转换时使用友元(friend)模板函数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
模板函數須要類型轉換時使用友元(friend)模板函數
本文地址:?http://blog.csdn.net/caroline_wendy/article/details/24357301
非模板函數參考:?http://blog.csdn.net/caroline_wendy/article/details/24309293
模板函數的隱式(implicit)類型轉換, 涉及到模板參數(typename)的確定問題.?
從int或double類型, 無法隱式轉換為模板類(template class)的類型, 由于無法確定模板參數類型(typename), 就無法確定構造函數的參數.
所以須要使模板函數, 與模板類擁有同樣的參數類型(typename), 則須要成為模板類的友元(friend).
模板類的友元, 會隨著類的參數實例化, 而實例化參數類型, 從一個函數模板, 生成定制的函數, 即能夠通過隱式類型轉換.
由于生成了定制的函數, 所以無法找到外部的模板類定義, 能夠通過:
1. 直接在友元函數內部, 實現代碼(inline);
2. 在友元函數內部, 實現一個模板函數, 在把模板函數在外部實現.
代碼例如以下:
/** test.cpp** Created on: 2014.04.22* Author: Spike*//*eclipse cdt, gcc 4.8.1*/#include <iostream>template<typename T> class Rational;template<typename T> const Rational<T> doMultiply (const Rational<T>& lhs,const Rational<T>& rhs);//有理數 template<typename T> class Rational {/*friend const Rational<T> operator* (const Rational<T>& lhs,const Rational<T>& rhs) {return Rational<T>(lhs.numerator()*rhs.numerator(),lhs.denominator()*rhs.denominator());} //方法1*/friend const Rational<T> operator* (const Rational<T>& lhs,const Rational<T>& rhs) {return doMultiply(lhs, rhs);} //方法2 public:Rational(const T& numerator = 0, const T& denominator = 1) :m_n(numerator), m_d(denominator) {}const T numerator() const {return m_n;};const T denominator() const {return m_d;};const T value() {return (m_n/m_d);} private:T m_n;T m_d; };template<typename T> const Rational<T> doMultiply (const Rational<T>& lhs,const Rational<T>& rhs) {return Rational<T>(lhs.numerator()*rhs.numerator(),lhs.denominator()*rhs.denominator()); }int main(void) {Rational<double> oneFourth(1, 4);Rational<double> result;result = oneFourth * 3.5;result = 3.5 * oneFourth;std::cout << "result = " << result.value() << std::endl;return 0; }輸出:
result = 0.875
總結
以上是生活随笔為你收集整理的C++ - 模板函数须要类型转换时使用友元(friend)模板函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Hello World, S/4HANA
- 下一篇: 仔细讨论 C/C++ 字节对齐问题⭐⭐