- regex[meta header]
- std[meta namespace]
- match_results[meta class]
- function[meta id-type]
- cpp11[meta cpp]
bool empty() const; // C++11
[[nodiscard]] bool empty() const; // C++20
*this
が空か否か(つまり、マッチが失敗したか否か)を返す。
size
() == 0
regex_match
、および、regex_search
の引数に渡したmatch_results
オブジェクトは、マッチが成功するとempty() != true
となる。
match_results
オブジェクトの結果が利用可能か否かを確認する場合にはready
を使用すると良い。regex_iterator
を間接参照して得られるmatch_results
オブジェクトは、必ずempty() != true
となる。empty() == true
の場合、match_results
のメンバ関数には結果が未規定であるものがあるので、注意が必要である(regex_match
、および、regex_search
を参照)。- 本メンバ関数は
ready
() == false
でも呼び出すことが可能である(その場合、true
が返される)。
#include <iostream>
#include <regex>
int main()
{
const char s1[] = " abc ";
const char s2[] = " 012 ";
const std::regex re("\\d+");
std::cmatch m;
// regex_search 実行前
std::cout << std::boolalpha << "ready = " << m.ready() << ", empty = " << m.empty() << std::endl;
// regex_search 実行後(マッチ失敗)
if (std::regex_search(s1, m, re)) {
std::cout << "match:ready = " << m.ready() << ", empty = " << m.empty() << std::endl;
} else {
std::cout << "not match:ready = " << m.ready() << ", empty = " << m.empty() << std::endl;
}
// regex_search 実行後(マッチ成功)
if (std::regex_search(s2, m, re)) {
std::cout << "match:ready = " << m.ready() << ", empty = " << m.empty() << std::endl;
} else {
std::cout << "not match:ready = " << m.ready() << ", empty = " << m.empty() << std::endl;
}
}
- empty()[color ff0000]
- std::regex[link ../basic_regex.md]
- std::cmatch[link ../match_results.md]
- std::regex_search[link ../regex_search.md]
- m.ready()[link ready.md]
ready = false, empty = true
not match:ready = true, empty = true
match:ready = true, empty = false
- C++11
- Clang: -
- Clang, C++11 mode: 3.0, 3.1, 3.2, 3.3, 3.4, 3.5, 3.6
- GCC: -
- GCC, C++11 mode: 4.9.0, 4.9.1, 5.0.0
- ICC: ??
- Visual C++: ??