COPYSIGN(3) Руководство программиста Linux COPYSIGN(3)

ИМЯ

copysign, 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():

_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L || /* начиная с glibc 2.19: */ _DEFAULT_SOURCE || /* версии glibc <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE

ОПИСАНИЕ

Эти функции возвращают величину, чье абсолютное значение равно 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, эти функции могут считать отрицательный ноль как положительный.

СМОТРИТЕ ТАКЖЕ

signbit(3)

2017-09-15 GNU