Merge bitcoin/bitcoin#29469: doc: document preference for list-initialization

eb5d78c649 doc: document preference for list-initialization (Andrew Toth)

Pull request description:

  Variable initialization is very complex in C++. There seems to be some consensus that when in doubt, use list-initialization.

  https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#Res-list
  https://www.learncpp.com/cpp-tutorial/variable-assignment-and-initialization/

ACKs for top commit:
  maflcko:
    ACK eb5d78c649

Tree-SHA512: 80d52b062d9e3a0115242779b11385ab583b4c71b27725f63b0a8f82174c04718a57f55a7c1a6df76b405102b175c66abb479589caf363e5d12784e78ad04a93
This commit is contained in:
fanquake 2024-02-26 10:55:32 +00:00
commit d0a9e339a9
No known key found for this signature in database
GPG key ID: 2EEB9F5CC09526C1

View file

@ -113,6 +113,8 @@ code.
between integer types, use functional casts such as `int(x)` or `int{x}` between integer types, use functional casts such as `int(x)` or `int{x}`
instead of `(int) x`. When casting between more complex types, use `static_cast`. instead of `(int) x`. When casting between more complex types, use `static_cast`.
Use `reinterpret_cast` and `const_cast` as appropriate. Use `reinterpret_cast` and `const_cast` as appropriate.
- Prefer [`list initialization ({})`](https://isocpp.github.io/CppCoreGuidelines/CppCoreGuidelines#Res-list) where possible.
For example `int x{0};` instead of `int x = 0;` or `int x(0);`
For function calls a namespace should be specified explicitly, unless such functions have been declared within it. For function calls a namespace should be specified explicitly, unless such functions have been declared within it.
Otherwise, [argument-dependent lookup](https://en.cppreference.com/w/cpp/language/adl), also known as ADL, could be Otherwise, [argument-dependent lookup](https://en.cppreference.com/w/cpp/language/adl), also known as ADL, could be
@ -138,7 +140,7 @@ int main()
Block style example: Block style example:
```c++ ```c++
int g_count = 0; int g_count{0};
namespace foo { namespace foo {
class Class class Class
@ -150,7 +152,7 @@ public:
{ {
// Comment summarising what this section of code does // Comment summarising what this section of code does
for (int i = 0; i < n; ++i) { for (int i = 0; i < n; ++i) {
int total_sum = 0; int total_sum{0};
// When something fails, return early // When something fails, return early
if (!Something()) return false; if (!Something()) return false;
... ...