copysign(3) копирует знак числа

Other Alias

copysignf, copysignl

ОБЗОР

#include <math.h>


double copysign(double x, double y);
float copysignf(float x, float y);
long double copysignl(long double x, long double y);

Компонуется при указании параметра -lm.

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

copysign(), copysignf(), copysignl():

_SVID_SOURCE || _BSD_SOURCE || _XOPEN_SOURCE >= 600 || _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L;
или cc -std=c99

ОПИСАНИЕ

Эти функции возвращают величину, чье абсолютное значение равно x, но знак которой соответствует знаку значения y.

Например, copysign(42.0, -1.0) и copysign(-42.0, -1.0) вернут -42.0.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении данные функции возвращают значение величиной как у x и знаком как у y.

Если x равно NaN, будет возвращено NaN со знаковым битом как у y.

ОШИБКИ

Ошибки не возникают.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
ИнтерфейсАтрибутЗначение
copysign(), copysignf(), copysignl() безвредность в нитяхбезвредно (MT-Safe)

СООТВЕТСТВИЕ СТАНДАРТАМ

C99, POSIX.1-2001, POSIX.1-2008. Эта функция определена в IEC 559 (и в приложении с рекомендуемыми функциями IEEE 754/IEEE 854).

ЗАМЕЧАНИЯ

На архитектурах, у которых форматы чисел с плавающей запятой не совместимы с IEEE 754, эти функции могут считать отрицательный ноль как положительный.