名前空間
変種
操作

std::invalid_argument

提供: cppreference.com
< cpp‎ | error
 
 
ユーティリティライブラリ
汎用ユーティリティ
日付と時間
関数オブジェクト
書式化ライブラリ (C++20)
(C++11)
関係演算子 (C++20で非推奨)
整数比較関数
(C++20)
スワップと型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
一般的な語彙の型
(C++11)
(C++17)
(C++17)
(C++17)
(C++17)

初等文字列変換
(C++17)
(C++17)
 
エラー処理
例外処理
例外処理の失敗
(C++17未満)
(C++17未満)
(C++11)(C++17未満)
(C++17未満)
エラー番号
エラー番号
例外のカテゴリ
invalid_argument
アサーション
システムエラー
(C++11)
(C++11)
 
 
ヘッダ <stdexcept> で定義
class invalid_argument;

例外として投げるオブジェクトの型を定義します。 引数の値が受理されないために発生するエラーを報告します。

この例外は std::bitset::bitset および std::stoi, std::stof ファミリーの関数によって投げられます。

cpp/error/exceptioncpp/error/logic errorstd-invalid argument-inheritance.svg
画像の詳細

継承図

目次

[編集] メンバ関数

コンストラクタ
例外オブジェクトを構築します
(パブリックメンバ関数) [edit]

std::invalid_argument::invalid_argument

explicit invalid_argument( const std::string& what_arg );
(1)
explicit invalid_argument( const char* what_arg );
(2) (C++11以上)

what() でアクセス可能な説明文字列として what_arg を持つ例外オブジェクトを構築します。

std::invalid_argument のコピーが例外を投げることは許されないため、このメッセージは内部的には一般的に別に確保された参照カウント管理の文字列として格納されます。 これは std::string&& を取るコンストラクタが無い理由でもあります。 どのみち内容をコピーしなければならないのです。

引数

what_arg - 説明文字列

例外

std::bad_alloc を投げる場合があります

std::exception から継承

メンバ関数

例外オブジェクトを破棄します
(std::exceptionの仮想パブリックメンバ関数) [edit]
[仮想]
説明文字列を返します
(std::exceptionの仮想パブリックメンバ関数) [edit]

[編集] ノート

この例外型の目的はエラー状態 std::errc::invalid_argument (std::thread のメンバ関数から std::system_error 内で投げられる) および関連するエラーコード EINVAL と同様です。