std::empty
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    | 定义于头文件  <array> | ||
| 定义于头文件  <deque> | ||
| 定义于头文件  <forward_list> | ||
| 定义于头文件  <iterator> | ||
| 定义于头文件  <list> | ||
| 定义于头文件  <map> | ||
| 定义于头文件  <regex> | ||
| 定义于头文件  <set> | ||
| 定义于头文件  <span> | (C++20 起) | |
| 定义于头文件  <string> | ||
| 定义于头文件  <string_view> | (C++17 起) | |
| 定义于头文件  <unordered_map> | ||
| 定义于头文件  <unordered_set> | ||
| 定义于头文件  <vector> | ||
| (1) | ||
| template <class C> constexpr auto empty(const C& c) -> decltype(c.empty()); | (C++17 起) (C++20 前) | |
| template <class C> [[nodiscard]] constexpr auto empty(const C& c) -> decltype(c.empty()); | (C++20 起) | |
| (2) | ||
| template <class T, std::size_t N> constexpr bool empty(const T (&array)[N]) noexcept; | (C++17 起) (C++20 前) | |
| template <class T, std::size_t N> [[nodiscard]] constexpr bool empty(const T (&array)[N]) noexcept; | (C++20 起) | |
| (3) | ||
| template <class E> constexpr bool empty(std::initializer_list<E> il) noexcept; | (C++17 起) (C++20 前) | |
| template <class E> [[nodiscard]] constexpr bool empty(std::initializer_list<E> il) noexcept; | (C++20 起) | |
返回给定的范围是否为空。
1) 返回 c.empty()
2) 返回 false
3) 返回 il.size() == 0
参数
| c | - | 拥有 empty成员函数的容器或视图 | 
| array | - | 任意类型的数组 | 
| il | - | 一个 initializer_list | 
返回值
若范围不含有任何元素则为 true 。
异常
1) 可能抛出实现定义的异常。
注解
需要对 std::initializer_list 的重载,因为它无成员函数 empty 。
可能的实现
| 版本一 | 
|---|
| template <class C> [[nodiscard]] constexpr auto empty(const C& c) -> decltype(c.empty()) { return c.empty(); } | 
| 版本二 | 
| template <class T, std::size_t N> [[nodiscard]] constexpr bool empty(const T (&array)[N]) noexcept { return false; } | 
| 版本三 | 
| template <class E> [[nodiscard]] constexpr bool empty(std::initializer_list<E> il) noexcept { return il.size() == 0; } | 
示例
运行此代码
#include <iostream> #include <vector> template <class T> void print(const T& container) { if ( !std::empty(container) ) { std::cout << "Elements:\n"; for ( const auto& element : container ) std::cout << element << '\n'; } else { std::cout << "Empty\n"; } } int main() { std::vector<int> c = { 1, 2, 3 }; print(c); c.clear(); print(c); int array[] = { 4, 5, 6 }; print(array); auto il = { 7, 8, 9 }; print(il); }
输出:
Elements: 1 2 3 Empty Elements: 4 5 6 Elements: 7 8 9
参阅
| (C++20) | 检查范围是否为空 (定制点对象) |