Anfang Juni endete das Treffen der internationalen Arbeitsgruppe WG21 zur Normung C ++ in der Stadt Rapperswil-Yona.

Folgendes erwartet Sie unter dem Schnitt:
- VertrÀge und Freunde
- Konzepte (keine Freunde)
- __has_cpp_attribute (unwahrscheinlich)
- bit_cast <my_stuff> (some_array)
- enthÀlt Shift_Left , Shift_Right , Ispow2 , Ceil2 ... und alte Algorithmen mit einer neuen Sauce
- atomic_ref
- Was neu in Vorlagen geschrieben werden kann und wie nĂŒtzlich es ist
- constexpr virtual foo ()
- ParallelitÀt 2, Reflexion und Executors TS
Es wird auch einen Bonus geben: Minisektion fĂŒr Experten:
- Der vom Benutzer deklarierte virtuelle Destruktor hat keinen Einfluss auf die TrivialitÀt des Typs
- Wo kann ich ein Ausrufezeichen setzen und wie kann es nĂŒtzlich sein?
- constexpr std :: regex mail_regex (R "((?: (?: [^ <> () \ [\].,;: \ s @ \"] + (?: \. [^ <> () \ [ \].,;: \ s @ "] +) *) |". + ") @ (?: (?: [^ <> () \ [\].,;: \ s @ \" ] + \.) + [^ <> () \ [\].,;: \ s @ \ "] {2,}))")
VertrÀge
In C ++ 20 akzeptierten sie VertrĂ€ge. So wird es bald möglich sein, die Verwendung von Makros fĂŒr Zusicherungen zu vergessen, die beste Dokumentation sofort zu erhalten und sogar eine Leistungssteigerung zu bemerken. In der Praxis sehen VertrĂ€ge folgendermaĂen aus:
std::string get_name_by_login(std::string_view login)
[[expects: !login.empty() ]]
[[ensures ret_value: !ret_value.empty() ]]
;
, , . , :
- ( ) .
- ( ) . , , .
- (, doxygen) / .
- , (, ).
.
21 Fails, . , :
void(const std::contract_violation & e) noexcept {
std::cerr << "Contract violated in function " << e.function_name() << '\n'
<< std::stacktrace();
}
:
Contract violated in function std::array<T, N>::operator[](size_type) [with T = int; long unsigned int N = 5ul; ]':
0# std::array<int, 5ul>::operator[](unsigned long) at /usr/include/c++/array:124
1# bar(int) at ../example/assert_handler.cpp:17
2# foo(int) at ../example/assert_handler.cpp:25
3# main at ../example/assert_handler.cpp:54
4# 0x00007F991FD69F45 in /lib/x86_64-linux-gnu/libc.so.6
5# 0x0000000000401139
}
std::stacktrace C++20, design review LEWG, LWG.
.
, Ranges TS. compile-time :
template <class F>
requires Invocable<F>
void my_executor::execute(F f) noexcept {
lock_guard l{data_mutex_};
push(std::move(f));
}
proposal.
Feature-test macros
. .
unlikely,
__has_cpp_attribute(unlikely).
,
.
bit_cast
reinterpret_cast â . , . C++ .
,
my_type my = reinterpret_cast<my_type&>(some_array);
my_type my = std::bit_cast<my_type>(some_array);
, some_array my_type , , . , type aliasing.
, C++20:
- shift_left(it_begin, it_end, unsigned n) â n, *it_begin = std::move(*(it_begin + n)), *(it_begin + 1) = std::move(*(it_begin + n + 1))...
- shift_right(it_begin, it_end, unsigned n) â , , *(it_begin + n) = std::move(*it_begin), *(it_begin + n + 1) = std::move(*(it_begin + 1))...
- ispow2(x) â true ,
- ceil2(x) â ,
- contains â bool contains(const key& v), true
, ,
std::swap std::swap constexpr. ,
std::nth_element .
21.
atomic_ref
, - ? atomic_ref<T> (
).
, ,
atomic_ref<T>.
atomic_ref,
atomic_ref, .
, (string
_view, atomic
_ref),
. , .
X,
operator<=> :
struct X {
// ...
std::strong_equality operator<=>(const X&, const X&) = default;
// ...
};
:
template <X x>
struct x_as_template_param {
// ...
};
operator<=>.
constexpr virtual
, , constexpr .
constexpr virtual int foo();,
int foo() constexpr, .
foo() , constexpr .
, ,
std::type_info,
Boost.TypeIndex, compile-time :
template <class T, class U>
constexpr bool is_same() {
constexpr bool res = (typeid(T) == typeid(U));
return res;
}
.
Parallelism 2, Reflection Executors TS
Parallelism 2 ,
. type traits, simd .
Reflection (TS). ,
<type_traits>. constexpr
constexpr! (. ).
Executors C++20, , , TS. , .
user-declared virtual destructor
, C++20 ( ), , :
struct i_am_trivial {
int foo;
char bar;
virtual ~i_am_trivial() = default;
};
, , . , , , , . , ,
std::vector<Base>, Base .
constexpr!
, C++20 â
constexpr! .
, runtime . C++.
constexpr! . ..
constexpr! , ( ) . , . , ,
Boost.Hana [Boost.]PFR.
: constexpr std::regex
/ . , , .
C++ :
bool is_valid_mail(std::string_view mail) {
static const std::regex mail_regex(R"((?:(?:[^<>()\[\].,;:\s@\"]+(?:\.[^<>()\[\].,;:\s@\"]+)*)|\".+\")@(?:(?:[^<>()\[\].,;:\s@\"]+\.)+[^<>()\[\].,;:\s@\"]{2,}))");
return std::regex_match(
std::cbegin(mail),
std::cend(mail),
mail_regex
);
}
is_valid_mail(). , .
constexpr (constexpr new, is_constexpr_evaluated() .) C++ ,
constexpr std::regex.
constexpr std::regex is_valid_mail() . , GCC
static const, .. GCC-6
constexpr â , GCC .
,
constexpr std::regex?
P.S.: C++ Yandex.Taxi Coding Fest. C++17.