C++max的使用方法


#include <iostream>
//#include <algorithm>//std::min std::max
#include <stdint.h>
#include <Windows.h>
using namespace std;
//包含在c++標准庫中頭文件<algorithm>中,在頭文件<windows.h>中定義了min,max的宏,
//若在包含<algorithm>的同時包含<windows.h>會導致函數無法使用

int main()
{
    double d1 =(double)(INT64_MIN);
    double d2 =(double)(INT64_MAX);

    double dmin1 = min(0,d1);
    double dmin2 = min(d1,0);

    double dmax1 = max(0,d2);
    double dmax2 = max(d2,0);

    return 0;
}

 

//double 無效值表示方法
double Nan()
{
    UINT64 u = 0x7fffffffffffffff;

    return *(double*)&u;
}

int main()
{
    double d = Nan();


    double dmax3 = max(d,-1);
    double dmax4 = max(d,0);

    cout << "dmax3: " << dmax3 << endl;

    cout << "dmax4: " << dmax4 << endl;

    return 0;
}

 

注:#define max(a,b)            (((a) > (b)) ? (a) : (b))

 

無效值和有效值比較,問號前面的表達式永遠是假,所以返回b


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM