ldexp, ldexpf, ldexpl

Умножает число с плавающей запятой на целую степень числа два.

Синтаксис

double ldexp(
   double x,
   int exp
);
float ldexpf(
   float x,
   int exp
);
long double ldexpl(
   long double x,
   int exp
);
#define ldexp(X, INT) // Requires C11 or higher

float ldexp(
   float x,
   int exp
);  // C++ only
long double ldexp(
   long double x,
   int exp
);  // C++ only

Параметры

x
Значение с плавающей запятой.

exp
Целый показатель степени.

Возвращаемое значение

При ldexp успешном выполнении функции возвращают значение x * 2exp . При переполнении xldexp и в зависимости от знака возвращается +/- HUGE_VALзначение errnoERANGE.

Дополнительные сведения о значениях возврата ошибок см. в errno разделе errno, _doserrnoи _sys_errlist_sys_nerr.

Замечания

Поскольку C++ допускает перегрузку, можно вызывать перегрузки ldexp, которые принимают типы float или long double. В программе C, если вы не используете <макрос tgmath.h> для вызова этой функции, ldexp всегда принимает double и int возвращает значение double.

Если вы используете <макрос tgmath.h>ldexp() , тип аргумента определяет, какая версия функции выбрана. Дополнительные сведения см . в разделе "Математика с универсальным типом".

По умолчанию глобальное состояние этой функции ограничивается приложением. Чтобы изменить это поведение, см . статью "Глобальное состояние" в CRT.

Требования

Маршрут Заголовок C Заголовок C++
ldexp, ldexpf, ldexpl <math.h> <cmath>
ldexpМакрос <tgmath.h>

Дополнительные сведения о совместимости см. в разделе Совместимость.

Пример

// crt_ldexp.c

#include <math.h>
#include <stdio.h>

int main( void )
{
   double x = 4.0, y;
   int p = 3;

   y = ldexp( x, p );
   printf( "%2.1f times two to the power of %d is %2.1f\n", x, p, y );
}

Выходные данные

4.0 times two to the power of 3 is 32.0

См. также

Поддержка математических и плавающих точек
frexp
modf, modff, modfl