std::abs, std::labs, std::llabs, std::imaxabs
From cppreference.com
| ヘッダ <cstdlib> で定義 |
||
| ヘッダー <cmath> で定義 |
||
| int abs( int num ); |
(1) | (C++23 以降 constexpr) |
| long abs( long num ); |
(2) | (C++23 以降 constexpr) |
| long long abs( long long num ); |
(3) | (C++11以降) (C++23 以降 constexpr) |
| ヘッダ <cstdlib> で定義 |
||
| long labs( long num ); |
(4) | (C++23 以降 constexpr) |
| long long llabs( long long num ); |
(5) | (C++11以降) (C++23 以降 constexpr) |
| ヘッダー <cinttypes> で定義 |
||
| std::intmax_t abs( std::intmax_t num ); |
(6) | (C++11以降) (C++23 以降 constexpr) |
| std::intmax_t imaxabs( std::intmax_t num ); |
(7) | (C++11以降) (C++23 以降 constexpr) |
整数 num の絶対値を計算します。結果が戻り値の型で表現できない場合、動作は未定義です。
std::abs が、整数昇格によって int に変換できない符号なし整数引数で呼び出された場合、プログラムは不正形式となります。
|
|
(C++11以降) |
目次 |
[編集] パラメータ
| num | - | 整数値 |
[編集] 戻り値
num の絶対値(すなわち |num|)。ただし、表現可能な場合。
[編集] 注記
2の補数システムでは、最も負の値の絶対値は範囲外です。たとえば、32ビット2の補数型 int では、INT_MIN は -2147483648 ですが、結果となるはずの 2147483648 は、INT_MAX(2147483647)よりも大きくなります。
[編集] 例
このコードを実行
#include <climits> #include <cstdlib> #include <iostream> int main() { std::cout << std::showpos << "abs(+3) = " << std::abs(3) << '\n' << "abs(-3) = " << std::abs(-3) << '\n'; // std::cout << std::abs(INT_MIN); // undefined behavior on 2's complement systems }
出力
abs(+3) = +3 abs(-3) = +3
[編集] 不具合報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 2192 | C++98 | std::abs のオーバーロードが2つのヘッダーで一貫性のない宣言がされていました |
これらのオーバーロードを宣言しました 両方のヘッダーに |
[編集] 関連項目
| (C++11)(C++11) |
浮動小数点数値の絶対値 (|x|) (関数) |
| 複素数の大きさを返す (関数テンプレート) | |
| valarrayの各要素に関数absを適用する (function template) | |
| C のドキュメント (abs, labs, llabs)
| |