mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 10:43:19 -03:00
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: ACKeb5d78c649
Tree-SHA512: 80d52b062d9e3a0115242779b11385ab583b4c71b27725f63b0a8f82174c04718a57f55a7c1a6df76b405102b175c66abb479589caf363e5d12784e78ad04a93
This commit is contained in:
commit
d0a9e339a9
1 changed files with 4 additions and 2 deletions
|
@ -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;
|
||||||
...
|
...
|
||||||
|
|
Loading…
Add table
Reference in a new issue