?
このドキュメントでは、 php中國語ネットマニュアル リリース
在頭文件<math.h>中定義 | ||
---|---|---|
float copysignf( float x, float y ); | (1) | (since C99) |
double copysign( double x, double y ); | (2) | (since C99) |
long double copysignl( long double x, long double y ); | (3) | (since C99) |
Defined in header <tgmath.h> | ||
#define copysign(from, to) | (7) | (since C99) |
1-3)組成一個浮點值,其大小x
和符號為y
。
4)類型 - 通用宏:如果任何參數(shù)具有類型long double
,copysignl
則被調(diào)用。否則,如果任何參數(shù)具有整數(shù)類型或具有類型double
,copysign
則被調(diào)用。否則,copysignf
被調(diào)用。
x,y | - | 浮點值 |
---|
copysign(1.0,+2.0) = +1.0copysign(1.0,-2.0) = -1.0copysign(INFINITY,-2.0) = -infcopysign(NAN,-2.0) = -nan
如果x
是NaN,則y
返回帶有符號的NaN 。
C11標(biāo)準(zhǔn)(ISO / IEC 9899:2011):
7.12.11.1 copysign函數(shù)(p:255)
7.25類型通用數(shù)學(xué)<tgmath.h>(p:373-375)
F.10.8.1 copysign函數(shù)(p:529)
C99標(biāo)準(zhǔn)(ISO / IEC 9899:1999):
7.12.11.1 copysign函數(shù)(p:236)
7.22類型通用數(shù)學(xué)<tgmath.h>(p:335-337)
F.9.8.1 copysign函數(shù)(p:465)
此函數(shù)不受在math_errhandling中指定的任何錯誤的影響。
如果實現(xiàn)支持IEEE浮點運算(IEC 60559),
返回的值是精確的(FE_INEXACT
永遠不會被提升)并且獨立于當(dāng)前的舍入模式。
copysign
是操縱NaN值的符號的唯一便攜式方法(檢查NaN的符號,signbit
也可以使用)。
#include <stdio.h>#include <math.h> int main(void){ printf("copysign(1.0,+2.0) = %+.1f\n", copysign(1.0,+2.0)); printf("copysign(1.0,-2.0) = %+.1f\n", copysign(1.0,-2.0)); printf("copysign(INFINITY,-2.0) = %f\n", copysign(INFINITY,-2.0)); printf("copysign(NAN,-2.0) = %f\n", copysign(NAN,-2.0));}
可能的輸出:
copysign(1.0,+2.0) = +1.0copysign(1.0,-2.0) = -1.0copysign(INFINITY,-2.0) = -infcopysign(NAN,-2.0) = -nan
C11標(biāo)準(zhǔn)(ISO / IEC 9899:2011):
7.12.11.1 copysign函數(shù)(p:255)
7.25類型通用數(shù)學(xué)<tgmath.h>(p:373-375)
F.10.8.1 copysign函數(shù)(p:529)
C99標(biāo)準(zhǔn)(ISO / IEC 9899:1999):
7.12.11.1 copysign函數(shù)(p:236)
7.22類型通用數(shù)學(xué)<tgmath.h>(p:335-337)
F.9.8.1 copysign函數(shù)(p:465)