名前空間
変種
操作

std::invalid_argument

提供: cppreference.com
< cpp‎ | error
 
 
 
 
 
ヘッダ <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::exception から派生する標準ライブラリのクラスはコピーされる際に例外を投げることが許されないため、このメッセージは一般的には別に確保された参照カウント管理の文字列として内部的に格納されます。 これは 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 と同様です。