C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- std::begin, std::cbegin
- std::end, std::cend
- std::next
- std::reverse_iterator
- std::rbegin, std::crbegin
- std::indirectly_readable
- std::indirectly_writable
- std::weakly_incrementable
- std::prev
- std::move_iterator
- std::size, std::ssize
- std::empty
- std::data
- std::insert_iterator
- std::rend, std::crend
- std::incrementable
- std::input_or_output_iterator
- std::sentinel_for
- std::sized_sentinel_for, std::disable_sized_sentinel_for
- std::input_iterator
- std::output_iterator
- std::forward_iterator
- std::bidirectional_iterator
- std::random_access_iterator
- std::contiguous_iterator
- std::iterator_traits
- std::input_iterator_tag, std::output_iterator_tag, std::forward_iterator_tag, std::bidirectional_iterator_tag, std::random_access_iterator_tag, std::contiguous_iterator_tag
- std::iterator
- std::incrementable_traits
- std::indirectly_readable_traits
- std::iter_value_t, std::iter_reference_t, std::iter_difference_t, std::iter_rvalue_reference_t, std::iter_common_reference_t
- std::indirect_unary_invocable, std::indirectly_regular_unary_invocable
- std::indirect_unary_predicate
- std::indirect_binary_predicate
- std::indirect_equivalence_relation
- std::indirect_strict_weak_order
- std::indirectly_movable
- std::indirectly_movable_storable
- std::indirectly_copyable
- std::indirectly_copyable_storable
- std::indirectly_swappable
- std::indirectly_comparable
- std::permutable
- std::mergeable
- std::sortable
- std::indirect_result_t
- std::projected
- std::move_sentinel
- std::back_insert_iterator
- std::front_insert_iterator
- std::make_reverse_iterator
- std::make_move_iterator
- std::default_sentinel_t, std::default_sentinel
- std::unreachable_sentinel_t, std::unreachable_sentinel
- std::back_inserter
- std::front_inserter
- std::inserter
- std::istream_iterator
- std::ostream_iterator
- std::istreambuf_iterator
- std::ostreambuf_iterator
- std::advance
- std::distance
- 注é
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >è¿ä»£å¨åº > std::empty
std::empty
| å®ä¹äºå¤´æä»¶ <iterator>
|
||
| (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 ã
注æ
é¤äºå
å«äº <iterator> ï¼è¥å
å«ä¸åä»»ä¸å¤´æä»¶ï¼åä¿è¯ std::empty å¯ç¨ï¼ <array> ã <deque> ã <forward_list> ã <list> ã <map> ã <regex> ã <set> ã <span> (C++20 èµ·) ã <string> ã <string_view> ã <unordered_map> ã <unordered_set> å <vector> ã
å¯è½çå®ç°
| çæ¬ä¸ |
|---|
template <class C> constexpr auto empty(const C& c) -> decltype(c.empty()) { return c.empty(); } |
| çæ¬äº |
template <class T, std::size_t N> constexpr bool empty(const T (&array)[N]) noexcept { return false; } |
| çæ¬ä¸ |
template <class E> 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