程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程綜合問答 >> c++-C++中函數重載的問題,為什麼沒有調用double Max,而是調用了int Max?

c++-C++中函數重載的問題,為什麼沒有調用double Max,而是調用了int Max?

編輯:編程綜合問答
C++中函數重載的問題,為什麼沒有調用double Max,而是調用了int Max?

函數Max有以下兩種重載形式:
int Max(int x, int y)
{
return x >= y ? x : y;
}
double Max(double x, double y)
{
return x >= y ? x : y;
}
在main函數中調用Max代碼如下
double m = 11.5, n = 15.5;
cout << “ Max=” << Max(m,n) << endl;

輸出 Max = 15,並警告 C4244: “參數”: 從“double”轉換到“int”,可能丟失數據

為什麼調用的是int Max(int x, int y) ?而不是double Max(double x, double y)?
有什麼辦法可以調用double Max(double x, double y)?

最佳回答:


不會吧,
除非調用處 看不到 重載為double Max(double x, double y)的函數,
不會出現這個問題的
這麼簡單的重載,C++很容易解析的

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved