std::trunc, std::truncf, std::truncl
提供: cppreference.com
<tbody>
</tbody>
| ヘッダ <cmath> で定義
|
||
float trunc ( float arg ); float truncf( float arg ); |
(1) | (C++11以上) |
double trunc ( double arg ); |
(2) | (C++11以上) |
long double trunc ( long double arg ); long double truncl( long double arg ); |
(3) | (C++11以上) |
double trunc ( 整数型 arg ); |
(4) | (C++11以上) |
1-3) 絶対値が
arg より大きくない最も近い整数を計算します。引数
| arg | - | 浮動小数点値 |
戻り値
エラーが発生しなければ、絶対値が arg より大きくない最も近い整数 (別の言い方をすると、ゼロに向かって丸めた arg) が返されます。
エラー処理
math_errhandling で規定されている通りにエラーが報告されます。
処理系が IEEE 浮動小数点算術 (IEC 60559) をサポートしている場合、
- 現在の丸めモードは効果を持ちません。
argが ±∞ であれば、それが変更されずに返されます。argが ±0 であれば、それが変更されずに返されます。argが NaN であれば、 NaN が返されます。
ノート
非整数の有限な値を丸めるとき、 FE_INEXACT が発生するかもしれません (が要求されているわけではありません)。
すべての標準の浮動小数点フォーマットにおいて、最も大きな表現可能な浮動小数点値は正確な整数であるため、この関数それ自体はオーバーフローすることはありません。 しかし任意の整数型 (std::intmax_t も含みます) は、整数変数に格納するとき、結果がオーバーフローするかもしれません。
浮動小数点から整数型への暗黙の変換もゼロに向かって丸めますが、ターゲットの型で表現可能な値に限定されます。
例
Run this code
#include <cmath>
#include <iostream>
int main()
{
std::cout << std::fixed
<< "trunc(+2.7) = " << std::trunc(+2.7) << '\n'
<< "trunc(-2.9) = " << std::trunc(-2.9) << '\n'
<< "trunc(-0.0) = " << std::trunc(-0.0) << '\n'
<< "trunc(-Inf) = " << std::trunc(-INFINITY) << '\n';
}
出力例:
trunc(+2.7) = 2.000000
trunc(-2.9) = -2.000000
trunc(-0.0) = -0.000000
trunc(-Inf) = -inf
関連項目
(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) |
最も近い整数を返します。 ちょうど中間の場合はゼロから離れる方向に丸めます (関数) |
trunc の C言語リファレンス
| |