std::copysign, std::copysignf, std::copysignl

来自cppreference.com
< cpp‎ | numeric‎ | math
 
 
数值库
常用数学函数
数学特殊函数 (C++17)
数学常数 (C++20)
浮点环境 (C++11)
复数
数值数组
伪随机数生成
编译时有理数算术 (C++11)
数值算法
(C++17)
(C++17)
插值
(C++20)
(C++20)
通用数值运算
(C++11)
位操作
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
(C++20)
 
常用数学函数
函数
基本运算
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
指数函数
(C++11)
(C++11)
(C++11)
(C++11)
幂函数
(C++11)
(C++11)
三角与双曲函数
(C++11)
(C++11)
(C++11)
误差与伽马函数
(C++11)
(C++11)
(C++11)
(C++11)
临近整数的浮点运算
(C++11)(C++11)(C++11)
(C++11)
(C++11)
(C++11)(C++11)(C++11)
浮点操作函数
(C++11)(C++11)
(C++11)
(C++11)
(C++11)(C++11)
copysign
(C++11)
分类/比较
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
宏常量
(C++11)(C++11)(C++11)(C++11)(C++11)
 
定义于头文件 <cmath>
float       copysign ( float x, float y );
float       copysignf( float x, float y );
(1) (C++11 起)
double      copysign ( double x, double y );
(2) (C++11 起)
long double copysign ( long double x, long double y );
long double copysignl( long double x, long double y );
(3) (C++11 起)
Promoted    copysign ( Arithmetic1 x, Arithmetic2 y );
(4) (C++11 起)
1-3)x 的模和 y 的符号组成浮点值。
4) 重载集或函数模板,用于所有 (1-3) 所不覆盖的算术类型参数组合。若任何参数拥有整数类型,则将它转型到 double 。若任何参数为 long double ,则返回类型 Promoted 亦为 long double , 否则返回类型始终是 double

参数

x, y - 浮点值

返回值

若无错误发生,则返回以 x 的模与 y 的符号组成的浮点值。

x 为 NaN ,则返回带 y 符号的 NaN 。

y 为 -0 ,则仅若实现支持与算术运算一致的有符号零,结果才为负。

错误处理

此函数不受制于任何指定于 math_errhandling 的错误

若实现支持 IEEE 浮点算术( IEC 60559 ),则

注意

std::copysign 是操作 NaN 值符号的唯一可移植方式( signbit 亦可用于检验 NaN 的符号)

示例

#include <iostream>
#include <cmath>
 
int main(void)
{
    std::cout << "copysign(1.0,+2.0) = " << std::copysign(1.0,+2.0) << '\n'
              << "copysign(1.0,-2.0) = " << std::copysign(1.0,-2.0) << '\n'
              << "copysign(inf,-2.0) = " << std::copysign(INFINITY,-2.0) << '\n'
              << "copysign(NaN,-2.0) = " << std::copysign(NAN,-2.0) << '\n';
}

输出:

copysign(1.0,+2.0) = 1
copysign(1.0,-2.0) = -1
copysign(inf,-2.0) = -inf
copysign(NaN,-2.0) = -nan

参阅

浮点值的绝对值(|x|
(函数)
(C++11)
检查给定数是否为负
(函数)