mirror of
https://github.com/google/styleguide.git
synced 2024-03-22 13:11:43 +08:00
Update to current.
This notably includes changes for namespace naming and use of auto, as well as clarification on when comments are necessary and attribute placement.
This commit is contained in:
parent
8c5b3b4d60
commit
5f113aa5c3
669
cppguide.html
669
cppguide.html
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
<h2 class="ignoreLink" id="Background">Background</h2>
|
<h2 class="ignoreLink" id="Background">Background</h2>
|
||||||
|
|
||||||
<p>C++ is the main development language used by
|
<p>C++ is one of the main development languages used by
|
||||||
many of Google's open-source projects. As every C++
|
many of Google's open-source projects. As every C++
|
||||||
programmer knows, the language has many powerful features, but
|
programmer knows, the language has many powerful features, but
|
||||||
this power brings with it complexity, which in turn can make
|
this power brings with it complexity, which in turn can make
|
||||||
|
@ -179,36 +179,37 @@ pitfalls of using header files.</p>
|
||||||
<h3 id="Self_contained_Headers">Self-contained Headers</h3>
|
<h3 id="Self_contained_Headers">Self-contained Headers</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Header files should be self-contained and end in <code>.h</code>. Files that
|
<p>Header files should be self-contained (compile on their own) and
|
||||||
are meant for textual inclusion, but are not headers, should end in
|
end in <code>.h</code>. Non-header files that are meant for inclusion
|
||||||
<code>.inc</code>. Separate <code>-inl.h</code> headers are disallowed.</p>
|
should end in <code>.inc</code>. </p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
<p>All header files should be self-contained. In other
|
<p>All header files should be self-contained. Users and refactoring
|
||||||
words, users and refactoring tools should not have to adhere to special
|
tools should not have to adhere to special conditions to include the
|
||||||
conditions in order to include the header. Specifically, a
|
header. Specifically, a header should
|
||||||
header should have <a href="#The__define_Guard">header guards</a>,
|
have <a href="#The__define_Guard">header guards</a> and include all
|
||||||
should include all other headers it needs, and should not require any
|
other headers it needs.</p>
|
||||||
particular symbols to be defined.</p>
|
|
||||||
|
|
||||||
<p>There are rare cases where a file is not meant to be self-contained, but
|
<p>If a template or inline function is declared in a <code>.h</code>
|
||||||
instead is meant to be textually included at a specific point in the code.
|
file, that same header should provide its definition. The definitions
|
||||||
Examples are files that need to be included multiple times or
|
of these constructs must be included into every <code>.cc</code> file
|
||||||
platform-specific extensions that essentially are part of other headers. Such
|
that uses them, or the program may fail to link in some build
|
||||||
files should use the file extension <code>.inc</code>.</p>
|
configurations. Do not move these definitions to separately included
|
||||||
|
header files (<code>-inl.h</code>); this practice was common in the
|
||||||
|
past, but is no longer allowed.</p>
|
||||||
|
|
||||||
<p>If a template or inline function is declared in a <code>.h</code> file,
|
<p>As an exception, a template that is explicitly instantiated for
|
||||||
define it in that same file. The definitions of these constructs must
|
all relevant sets of template arguments, or that is a private
|
||||||
be included into every <code>.cc</code> file that uses them, or the
|
implementation detail of a class, is allowed to be defined in the one
|
||||||
program may fail to link in some build configurations. Do not move these
|
and only <code>.cc</code> file that instantiates the template.</p>
|
||||||
definitions to separate <code>-inl.h</code> files.</p>
|
|
||||||
|
|
||||||
<p>As an exception, a function template that is explicitly
|
<p>There are rare cases where a file is not meant to be
|
||||||
instantiated for all relevant sets of template arguments, or
|
self-contained, but it is meant to be included at a specific point in
|
||||||
that is a private member of a class, may
|
the code. Examples are files that need to be included multiple times
|
||||||
be defined in the only <code>.cc</code> file that
|
or platform-specific implementation details that are essentially part
|
||||||
instantiates the template.</p>
|
of other self-contained headers. Such files should use the file
|
||||||
|
extension <code>.inc</code>.</p>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -509,7 +510,8 @@ system-specific code small and localized. Example:</p>
|
||||||
<p>With few exceptions, place code in a namespace. Namespaces
|
<p>With few exceptions, place code in a namespace. Namespaces
|
||||||
should have unique names based on the project name, and possibly
|
should have unique names based on the project name, and possibly
|
||||||
its path. Unnamed namespaces in <code>.cc</code> files are
|
its path. Unnamed namespaces in <code>.cc</code> files are
|
||||||
encouraged. Do not use <i>using-directives</i>. Do not use
|
encouraged. Do not use <i>using-directives</i> (e.g.
|
||||||
|
<code>using namespace foo</code>). Do not use
|
||||||
inline namespaces.</p>
|
inline namespaces.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -732,7 +734,7 @@ external resources or have significant dependencies.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="decision">
|
<div class="decision">
|
||||||
<p>Sometimes it is useful, or even necessary, to define a
|
<p>Sometimes it is useful to define a
|
||||||
function not bound to a class instance. Such a function
|
function not bound to a class instance. Such a function
|
||||||
can be either a static member or a nonmember function.
|
can be either a static member or a nonmember function.
|
||||||
Nonmember functions should not depend on external
|
Nonmember functions should not depend on external
|
||||||
|
@ -758,7 +760,7 @@ class FooBar {
|
||||||
}
|
}
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
<p>If you must define a nonmember function and it is only
|
<p>If you define a nonmember function and it is only
|
||||||
needed in its <code>.cc</code> file, use an unnamed
|
needed in its <code>.cc</code> file, use an unnamed
|
||||||
<a href="#Namespaces">namespace</a> or
|
<a href="#Namespaces">namespace</a> or
|
||||||
<code>static</code> linkage (eg <code>static int Foo()
|
<code>static</code> linkage (eg <code>static int Foo()
|
||||||
|
@ -1097,10 +1099,10 @@ also omit <code>explicit</code>, in order to support copy-initialization
|
||||||
<h3 id="Copyable_Movable_Types">Copyable and Movable Types</h3>
|
<h3 id="Copyable_Movable_Types">Copyable and Movable Types</h3>
|
||||||
<a id="Copy_Constructors"></a>
|
<a id="Copy_Constructors"></a>
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Support copying and/or moving if it makes sense for your type.
|
<p>Support copying and/or moving if these operations are clear and meaningful
|
||||||
Otherwise, disable the implicitly generated special
|
for your type. Otherwise, disable the implicitly generated special functions
|
||||||
functions that perform copies and moves.</p>
|
that perform copies and moves.
|
||||||
</div>
|
</p></div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
|
||||||
|
@ -1122,15 +1124,15 @@ in some situations, e.g. when passing objects by value.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="pros">
|
<div class="pros">
|
||||||
<p>Objects of copyable and movable types can be passed and returned
|
<p>Objects of copyable and movable types can be passed and returned by value,
|
||||||
by value, which makes APIs simpler, safer, and more general.
|
which makes APIs simpler, safer, and more general. Unlike when passing objects
|
||||||
Unlike when passing pointers or references, there's no risk of
|
by pointer or reference, there's no risk of confusion over ownership,
|
||||||
confusion over ownership, lifetime, mutability, and similar
|
lifetime, mutability, and similar issues, and no need to specify them in the
|
||||||
issues, and no need to specify them in the contract. It also
|
contract. It also prevents non-local interactions between the client and the
|
||||||
prevents non-local interactions between the client and the
|
implementation, which makes them easier to understand, maintain, and optimize by
|
||||||
implementation, which makes them easier to understand and
|
the compiler. Further, such objects can be used with generic APIs that
|
||||||
maintain. Such objects can be used with generic
|
require pass-by-value, such as most containers, and they allow for additional
|
||||||
APIs that require pass-by-value, such as most containers.</p>
|
flexibility in e.g., type composition.</p>
|
||||||
|
|
||||||
<p>Copy/move constructors and assignment operators are usually
|
<p>Copy/move constructors and assignment operators are usually
|
||||||
easier to define correctly than alternatives
|
easier to define correctly than alternatives
|
||||||
|
@ -1151,54 +1153,39 @@ in some cases.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="cons">
|
<div class="cons">
|
||||||
<p>Many types do not need to be copyable, and providing copy
|
<p>Some types do not need to be copyable, and providing copy
|
||||||
operations for them can be confusing, nonsensical, or outright
|
operations for such types can be confusing, nonsensical, or outright
|
||||||
incorrect. Copy/assigment operations for base class types are
|
incorrect. Types representing singleton objects (<code>Registerer</code>),
|
||||||
hazardous, because use of them can lead to
|
objects tied to a specific scope (<code>Cleanup</code>), or closely coupled to
|
||||||
<a href="https://en.wikipedia.org/wiki/Object_slicing">object
|
object identity (<code>Mutex</code>) cannot be copied meaningfully.
|
||||||
slicing</a>. Defaulted or carelessly-implemented copy operations
|
Copy operations for base class types that are to be used
|
||||||
can be incorrect, and the resulting bugs can be confusing and
|
polymorphically are hazardous, because use of them can lead to
|
||||||
difficult to diagnose.</p>
|
<a href="http://en.wikipedia.org/wiki/Object_slicing">object slicing</a>.
|
||||||
|
Defaulted or carelessly-implemented copy operations can be incorrect, and the
|
||||||
|
resulting bugs can be confusing and difficult to diagnose.</p>
|
||||||
|
|
||||||
<p>Copy constructors are invoked implicitly, which makes the
|
<p>Copy constructors are invoked implicitly, which makes the
|
||||||
invocation easy to miss. This may cause confusion, particularly
|
invocation easy to miss. This may cause confusion for programmers used to
|
||||||
for programmers used to languages where pass-by-reference is
|
languages where pass-by-reference is conventional or mandatory. It may also
|
||||||
conventional or mandatory. It may also encourage excessive
|
encourage excessive copying, which can cause performance problems.</p>
|
||||||
copying, which can cause performance problems.</p>
|
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="decision">
|
<div class="decision">
|
||||||
|
|
||||||
<p>Make your type copyable/movable if it will be useful, and if it makes sense
|
<p>Provide the copy and move operations if their meaning is clear to a casual
|
||||||
in the context of the rest of the API. As a rule of thumb, if the behavior
|
user and the copying/moving does not incur unexpected costs. If you define a
|
||||||
(including computational complexity) of a copy isn't immediately obvious to
|
copy or move constructor, define the corresponding assignment operator, and
|
||||||
users of your type, your type shouldn't be copyable. If you define a copy or
|
vice-versa. If your type is copyable, do not define move operations unless they
|
||||||
move constructor, define the corresponding assignment operator, and vice-versa.
|
are significantly more efficient than the corresponding copy operations. If your
|
||||||
If your type is copyable, do not define move operations unless they are
|
|
||||||
significantly more efficient than the corresponding copy operations. If your
|
|
||||||
type is not copyable, but the correctness of a move is obvious to users of the
|
type is not copyable, but the correctness of a move is obvious to users of the
|
||||||
type, you may make the type move-only by defining both of the move operations.
|
type, you may make the type move-only by defining both of the move operations.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<p>If your type provides copy operations, it is recommended that you design
|
<p>If your type provides copy operations, it is recommended that you design
|
||||||
your class so that the default implementation of those operations is correct
|
your class so that the default implementation of those operations is correct.
|
||||||
and that you explicitly define them with <code>= default</code>. Remember to
|
Remember to review the correctness of any defaulted operations as you would any
|
||||||
review the correctness of any defaulted operations as you would any other
|
other code, and to document that your class is copyable and/or cheaply movable
|
||||||
code.</p>
|
if that's an API guarantee.</p>
|
||||||
|
|
||||||
<pre>class Foo { // Copyable and movable type.
|
|
||||||
public:
|
|
||||||
Foo(Foo&& other) = default;
|
|
||||||
Foo(const Foo& other) = default;
|
|
||||||
Foo& operator=(Foo&& other) = default;
|
|
||||||
Foo& operator=(const Foo& other) = default;
|
|
||||||
|
|
||||||
private:
|
|
||||||
string field_;
|
|
||||||
};
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<pre class="badcode">class Foo {
|
<pre class="badcode">class Foo {
|
||||||
public:
|
public:
|
||||||
|
@ -1218,93 +1205,11 @@ copyable, provide a public virtual <code>Clone()</code>
|
||||||
method, and a protected copy constructor that derived classes
|
method, and a protected copy constructor that derived classes
|
||||||
can use to implement it.</p>
|
can use to implement it.</p>
|
||||||
|
|
||||||
<p>If you do not want to support copy/move operations on
|
<p>If you do not want to support copy/move operations on your type,
|
||||||
your type, explicitly disable them using <code>= delete</code> or
|
explicitly disable them using <code>= delete</code> in
|
||||||
whatever
|
the <code>public:</code> section. </p>
|
||||||
other mechanism your project uses.
|
|
||||||
|
|
||||||
</p></div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Delegating_and_inheriting_constructors">Delegating and Inheriting Constructors</h3>
|
|
||||||
|
|
||||||
<div class="summary">
|
|
||||||
<p> Use delegating and inheriting
|
|
||||||
constructors when they reduce code duplication.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="stylebody">
|
|
||||||
|
|
||||||
<div class="definition">
|
|
||||||
|
|
||||||
<p>Delegating and inheriting constructors are two
|
|
||||||
different features, both introduced in C++11, for
|
|
||||||
reducing code duplication in constructors. Delegating
|
|
||||||
constructors allow one of a class's constructors to
|
|
||||||
forward work to one of the class's other constructors,
|
|
||||||
using a special variant of the initialization list
|
|
||||||
syntax. For example:</p>
|
|
||||||
|
|
||||||
<pre>X::X(const string& name) : name_(name) {
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
X::X() : X("") {}
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<p>Inheriting constructors allow a derived class to have
|
|
||||||
its base class's constructors available directly, just as
|
|
||||||
with any of the base class's other member functions,
|
|
||||||
instead of having to redeclare them. This is especially
|
|
||||||
useful if the base has multiple constructors. For
|
|
||||||
example:</p>
|
|
||||||
|
|
||||||
<pre>class Base {
|
|
||||||
public:
|
|
||||||
Base();
|
|
||||||
Base(int n);
|
|
||||||
Base(const string& s);
|
|
||||||
...
|
|
||||||
};
|
|
||||||
|
|
||||||
class Derived : public Base {
|
|
||||||
public:
|
|
||||||
using Base::Base; // Base's constructors are redeclared here.
|
|
||||||
};
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<p>This is especially useful when <code>Derived</code>'s
|
|
||||||
constructors don't have to do anything more than calling
|
|
||||||
<code>Base</code>'s constructors.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="pros">
|
|
||||||
<p>Delegating and inheriting constructors reduce
|
|
||||||
verbosity and boilerplate, which can improve
|
|
||||||
readability.</p>
|
|
||||||
|
|
||||||
<p>Delegating constructors are familiar to Java
|
|
||||||
programmers.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="cons">
|
|
||||||
<p>It's possible to approximate the behavior of
|
|
||||||
delegating constructors by using a helper function.</p>
|
|
||||||
|
|
||||||
<p>Inheriting constructors may be confusing if a derived
|
|
||||||
class introduces new member variables, since the base
|
|
||||||
class constructor doesn't know about them.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="decision">
|
|
||||||
<p>Use delegating and inheriting constructors when they reduce
|
|
||||||
boilerplate and improve readability.
|
|
||||||
Be cautious about inheriting constructors when your derived class has
|
|
||||||
new member variables. Inheriting constructors may still be appropriate
|
|
||||||
in that case if you can use in-class member initialization
|
|
||||||
for the derived class's member variables.</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Structs_vs._Classes">Structs vs. Classes</h3>
|
<h3 id="Structs_vs._Classes">Structs vs. Classes</h3>
|
||||||
|
@ -1718,7 +1623,7 @@ be in the following order:</p>
|
||||||
<li>Constants (<code>static const</code> data
|
<li>Constants (<code>static const</code> data
|
||||||
members)</li>
|
members)</li>
|
||||||
|
|
||||||
<li>Constructors</li>
|
<li>Constructors and assignment operators</li>
|
||||||
|
|
||||||
<li>Destructor</li>
|
<li>Destructor</li>
|
||||||
|
|
||||||
|
@ -2190,8 +2095,6 @@ do use shared ownership, prefer to use
|
||||||
you need to be compatible with older versions of C++.
|
you need to be compatible with older versions of C++.
|
||||||
Never use <code>std::auto_ptr</code>. Instead, use
|
Never use <code>std::auto_ptr</code>. Instead, use
|
||||||
<code>std::unique_ptr</code>.</p>
|
<code>std::unique_ptr</code>.</p>
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -2628,9 +2531,10 @@ them.</p>
|
||||||
explicit type conversion is necessary. </p>
|
explicit type conversion is necessary. </p>
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
<li>Convert arithmetic types using brace initialization. This is
|
<li>Use brace initialization to convert arithmetic types
|
||||||
the safest approach because code will not compile if conversion can
|
(e.g. <code>int64{x}</code>). This is the safest approach because code
|
||||||
result in information loss. The syntax is also concise.</li>
|
will not compile if conversion can result in information loss. The
|
||||||
|
syntax is also concise.</li>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -2715,7 +2619,7 @@ may select a different overload than you expect).</li>
|
||||||
<li>The practice of building up output through chains
|
<li>The practice of building up output through chains
|
||||||
of <code><<</code> operators interferes with
|
of <code><<</code> operators interferes with
|
||||||
internationalization, because it bakes word order into the
|
internationalization, because it bakes word order into the
|
||||||
code, and streams' support for localization is <a href="https://www.boost.org/doc/libs/1_48_0/libs/locale/doc/html/rationale.html#rationale_why">
|
code, and streams' support for localization is <a href="http://www.boost.org/doc/libs/1_48_0/libs/locale/doc/html/rationale.html#rationale_why">
|
||||||
flawed</a>.</li>
|
flawed</a>.</li>
|
||||||
|
|
||||||
|
|
||||||
|
@ -3227,7 +3131,8 @@ uint64_t my_mask = 3ULL << 48;
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Be very cautious with macros. Prefer inline functions,
|
<p>Be very cautious with macros. Prefer inline functions,
|
||||||
enums, and <code>const</code> variables to macros.</p>
|
enums, and <code>const</code> variables to macros. Don't
|
||||||
|
use macros to define pieces of a C++ API.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -3236,6 +3141,26 @@ enums, and <code>const</code> variables to macros.</p>
|
||||||
the code the compiler sees. This can introduce unexpected
|
the code the compiler sees. This can introduce unexpected
|
||||||
behavior, especially since macros have global scope.</p>
|
behavior, especially since macros have global scope.</p>
|
||||||
|
|
||||||
|
<p>The problems introduced by macros are especially severe
|
||||||
|
when they are used to define pieces of a C++ API,
|
||||||
|
and still more so for public APIs. Every error message from
|
||||||
|
the compiler when developers incorrectly use that interface
|
||||||
|
now must explain how the macros formed the interface.
|
||||||
|
Refactoring and analysis tools have a dramatically harder
|
||||||
|
time updating the interface. As a consequence, we
|
||||||
|
specifically disallow using macros in this way.
|
||||||
|
For example, avoid patterns like:</p>
|
||||||
|
|
||||||
|
<pre class="badcode">class WOMBAT_TYPE(Foo) {
|
||||||
|
// ...
|
||||||
|
|
||||||
|
public:
|
||||||
|
EXPAND_PUBLIC_WOMBAT_API(Foo)
|
||||||
|
|
||||||
|
EXPAND_WOMBAT_COMPARISONS(Foo, ==, <)
|
||||||
|
};
|
||||||
|
</pre>
|
||||||
|
|
||||||
<p>Luckily, macros are not nearly as necessary in C++ as
|
<p>Luckily, macros are not nearly as necessary in C++ as
|
||||||
they are in C. Instead of using a macro to inline
|
they are in C. Instead of using a macro to inline
|
||||||
performance-critical code, use an inline function.
|
performance-critical code, use an inline function.
|
||||||
|
@ -3254,7 +3179,10 @@ lower-level libraries. And some of their special features
|
||||||
(like stringifying, concatenation, and so forth) are not
|
(like stringifying, concatenation, and so forth) are not
|
||||||
available through the language proper. But before using a
|
available through the language proper. But before using a
|
||||||
macro, consider carefully whether there's a non-macro way
|
macro, consider carefully whether there's a non-macro way
|
||||||
to achieve the same result.</p>
|
to achieve the same result. If you need to use a macro to
|
||||||
|
define an interface, contact
|
||||||
|
your project leads to request
|
||||||
|
a waiver of this rule.</p>
|
||||||
|
|
||||||
<p>The following usage pattern will avoid many problems
|
<p>The following usage pattern will avoid many problems
|
||||||
with macros; if you use macros, follow it whenever
|
with macros; if you use macros, follow it whenever
|
||||||
|
@ -3347,96 +3275,47 @@ memset(&data, 0, sizeof(data));
|
||||||
<h3 id="auto">auto</h3>
|
<h3 id="auto">auto</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Use <code>auto</code> to avoid type names that are just
|
<p>Use <code>auto</code> to avoid type names that are noisy, obvious,
|
||||||
clutter. Continue to use manifest type declarations when it
|
or unimportant - cases where the type doesn't aid in clarity for the
|
||||||
helps readability, and never use <code>auto</code> for
|
reader. Continue to use manifest type declarations when it helps
|
||||||
anything but local variables.</p>
|
readability, and never use <code>auto</code> for anything but local
|
||||||
|
variables.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
|
||||||
<div class="definition">
|
|
||||||
<p> In C++11, a variable whose type is given as <code>auto</code>
|
|
||||||
will be given a type that matches that of the expression used to
|
|
||||||
initialize it. You can use <code>auto</code> either to
|
|
||||||
initialize a variable by copying, or to bind a
|
|
||||||
reference.</p>
|
|
||||||
|
|
||||||
<pre>vector<string> v;
|
|
||||||
...
|
|
||||||
auto s1 = v[0]; // Makes a copy of v[0].
|
|
||||||
const auto& s2 = v[0]; // s2 is a reference to v[0].
|
|
||||||
</pre>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<p>The <code>auto</code> keyword is also used in an
|
|
||||||
unrelated C++11 feature: it's part of the syntax for a
|
|
||||||
new kind of function declaration with a
|
|
||||||
<a href="#trailing_return">trailing return type</a>.</p>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="pros">
|
<div class="pros">
|
||||||
<p>C++ type names can sometimes be long and cumbersome,
|
<p>
|
||||||
especially when they involve templates or namespaces. In
|
</p><ul>
|
||||||
a statement like:</p>
|
<li>C++ type names can be long and cumbersome, especially when they
|
||||||
|
involve templates or namespaces.</li>
|
||||||
<pre>sparse_hash_map<string, int>::iterator iter = m.find(val);
|
<li>When a C++ type name is repeated within a single declaration or a
|
||||||
</pre>
|
small code region, the repetition may not be aiding readability.</li>
|
||||||
|
<li>It is sometimes safer to let the type be specified by the type of
|
||||||
|
the initialization expression, since that avoids the possibility of
|
||||||
|
unintended copies or type conversions.</li>
|
||||||
|
</ul>
|
||||||
|
<p></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<p>the return type is hard to read, and obscures the
|
|
||||||
primary purpose of the statement. Changing it to:</p>
|
|
||||||
|
|
||||||
<pre>auto iter = m.find(val);
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<p>makes it more readable.</p>
|
|
||||||
|
|
||||||
<p>Without <code>auto</code> we are sometimes forced to
|
|
||||||
write a type name twice in the same expression, adding no
|
|
||||||
value for the reader, as in:</p>
|
|
||||||
|
|
||||||
<pre>diagnostics::ErrorStatus* status = new diagnostics::ErrorStatus("xyz");
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<p>Using <code>auto</code> makes it easier to use
|
|
||||||
intermediate variables when appropriate, by reducing the
|
|
||||||
burden of writing their types explicitly.</p>
|
|
||||||
|
|
||||||
<div class="cons">
|
<div class="cons">
|
||||||
|
|
||||||
<p>Sometimes code is clearer when types are manifest,
|
<p>Sometimes code is clearer when types are manifest,
|
||||||
especially when a variable's initialization depends on
|
especially when a variable's initialization depends on
|
||||||
things that were declared far away. In an expression
|
things that were declared far away. In expressions
|
||||||
like:</p>
|
like:</p>
|
||||||
|
|
||||||
|
<pre class="badcode">auto foo = x.add_foo();
|
||||||
<pre>auto i = x.Lookup(key);
|
auto i = y.Find(key);
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
<p>it may not be obvious what <code>i</code>'s type is,
|
<p>It may not be obvious what the resulting types are if the type
|
||||||
if <code>x</code> was declared hundreds of lines earlier.</p>
|
of <code>y</code> isn't very well known, or if <code>y</code> was
|
||||||
|
declared many lines earlier.</p>
|
||||||
|
|
||||||
<p>Programmers have to understand the difference between
|
<p>Programmers have to understand the difference between
|
||||||
<code>auto</code> and <code>const auto&</code> or
|
<code>auto</code> and <code>const auto&</code> or
|
||||||
they'll get copies when they didn't mean to.</p>
|
they'll get copies when they didn't mean to.</p>
|
||||||
|
|
||||||
<p>The interaction between <code>auto</code> and C++11
|
|
||||||
brace-initialization can be confusing. The exact
|
|
||||||
rules have been in flux, and compilers don't all
|
|
||||||
implement the final rules yet.
|
|
||||||
The declarations:</p>
|
|
||||||
|
|
||||||
<pre>auto x{3};
|
|
||||||
auto y = {3};
|
|
||||||
</pre>
|
|
||||||
|
|
||||||
<p>mean different things —
|
|
||||||
<code>x</code> is an <code>int</code>, while
|
|
||||||
<code>y</code> is a <code>std::initializer_list<int></code>.
|
|
||||||
The same applies to other normally-invisible proxy types.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>If an <code>auto</code> variable is used as part of an
|
<p>If an <code>auto</code> variable is used as part of an
|
||||||
interface, e.g. as a constant in a header, then a
|
interface, e.g. as a constant in a header, then a
|
||||||
programmer might change its type while only intending to
|
programmer might change its type while only intending to
|
||||||
|
@ -3446,12 +3325,47 @@ than intended.</p>
|
||||||
|
|
||||||
<div class="decision">
|
<div class="decision">
|
||||||
|
|
||||||
<p><code>auto</code> is permitted, for local variables
|
<p><code>auto</code> is permitted, for local variables only, when it
|
||||||
only. Do not use <code>auto</code> for file-scope or
|
increases readability, particularly as described below. Do not
|
||||||
namespace-scope variables, or for class members. Never
|
use <code>auto</code> for file-scope or namespace-scope variables, or
|
||||||
initialize an <code>auto</code>-typed variable with
|
for class members. Never initialize an <code>auto</code>-typed
|
||||||
a braced initializer list.
|
variable with a braced initializer list.</p>
|
||||||
</p></div>
|
|
||||||
|
<p>Specific cases where <code>auto</code> is allowed or encouraged:
|
||||||
|
</p><ul>
|
||||||
|
<li>(Encouraged) For iterators and other long/cluttery type names, particularly
|
||||||
|
when the type is clear from context (calls
|
||||||
|
to <code>find</code>, <code>begin</code>, or <code>end</code> for
|
||||||
|
instance).</li>
|
||||||
|
<li>(Allowed) When the type is clear from local context (in the same expression
|
||||||
|
or within a few lines). Initialization of a pointer or smart pointer
|
||||||
|
with calls
|
||||||
|
to <code>new</code>
|
||||||
|
commonly falls into this category, as does use of <code>auto</code> in
|
||||||
|
a range-based loop over a container whose type is spelled out
|
||||||
|
nearby.</li>
|
||||||
|
<li>(Allowed) When the type doesn't matter because it isn't being used for
|
||||||
|
anything other than equality comparison.</li>
|
||||||
|
<li>(Encouraged) When iterating over a map with a range-based loop
|
||||||
|
(because it is often assumed that the correct type
|
||||||
|
is <code>pair<KeyType,ValueType></code> whereas it is actually
|
||||||
|
<code>pair<const KeyType,ValueType></code>). This is
|
||||||
|
particularly well paired with local <code>key</code>
|
||||||
|
and <code>value</code> aliases for <code>.first</code>
|
||||||
|
and <code>.second</code> (often const-ref).
|
||||||
|
<pre class="code">for (const auto& item : some_map) {
|
||||||
|
const KeyType& key = item.first;
|
||||||
|
const ValType& value = item.second;
|
||||||
|
// The rest of the loop can now just refer to key and value,
|
||||||
|
// a reader can see the types in question, and we've avoided
|
||||||
|
// the too-common case of extra copies in this iteration.
|
||||||
|
}
|
||||||
|
</pre>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<p></p>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -3553,9 +3467,8 @@ means can be confusing.</p>
|
||||||
<h3 id="Lambda_expressions">Lambda expressions</h3>
|
<h3 id="Lambda_expressions">Lambda expressions</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Use lambda expressions where appropriate. Avoid
|
<p>Use lambda expressions where appropriate. Prefer explicit captures
|
||||||
default lambda captures when capturing <code>this</code> or
|
when the lambda will escape the current scope.</p>
|
||||||
if the lambda will escape the current scope.</p>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -3571,22 +3484,32 @@ functions as arguments. For example:</p>
|
||||||
});
|
});
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
They further allow capturing variables from the enclosing scope either
|
<p> They further allow capturing variables from the enclosing scope either
|
||||||
explicitly by name, or implicitly using a default capture. Default captures
|
explicitly by name, or implicitly using a default capture. Explicit captures
|
||||||
implicitly capture any variable referenced in the lambda body, including
|
require each variable to be listed, as
|
||||||
<code>this</code> if any members are used. The default capture must come
|
either a value or reference capture:</p>
|
||||||
first and be one of <code>&</code> for capture by reference or
|
|
||||||
<code>=</code> for capture by value, followed by any explicit captures which
|
|
||||||
differ from the default:
|
|
||||||
|
|
||||||
<pre>int weight = 3;
|
<pre>int weight = 3;
|
||||||
int sum = 0;
|
int sum = 0;
|
||||||
// Captures `weight` (implicitly) by value and `sum` by reference.
|
// Captures `weight` by value and `sum` by reference.
|
||||||
std::for_each(v.begin(), v.end(), [=, &sum](int x) {
|
std::for_each(v.begin(), v.end(), [weight, &sum](int x) {
|
||||||
sum += weight * x;
|
sum += weight * x;
|
||||||
});
|
});
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
|
|
||||||
|
Default captures implicitly capture any variable referenced in the
|
||||||
|
lambda body, including <code>this</code> if any members are used:
|
||||||
|
|
||||||
|
<pre>const std::vector<int> lookup_table = ...;
|
||||||
|
std::vector<int> indices = ...;
|
||||||
|
// Captures `lookup_table` by reference, sorts `indices` by the value
|
||||||
|
// of the associated element in `lookup_table`.
|
||||||
|
std::sort(indices.begin(), indices.end(), [&](int a, int b) {
|
||||||
|
return lookup_table[a] < lookup_table[b];
|
||||||
|
});
|
||||||
|
</pre>
|
||||||
|
|
||||||
<p>Lambdas were introduced in C++11 along with a set of utilities
|
<p>Lambdas were introduced in C++11 along with a set of utilities
|
||||||
for working with function objects, such as the polymorphic
|
for working with function objects, such as the polymorphic
|
||||||
wrapper <code>std::function</code>.
|
wrapper <code>std::function</code>.
|
||||||
|
@ -3614,19 +3537,20 @@ wrapper <code>std::function</code>.
|
||||||
|
|
||||||
<div class="cons">
|
<div class="cons">
|
||||||
<ul>
|
<ul>
|
||||||
<li>Default captures make it easy to overlook an
|
<li>Variable capture in lambdas can be a source of dangling-pointer
|
||||||
implicit capture and use of <code>this</code>.
|
bugs, particularly if a lambda escapes the current scope.</li>
|
||||||
</li>
|
|
||||||
|
|
||||||
<li>Variable capture in lambdas can be tricky, and
|
<li>Default captures by value can be misleading because they do not prevent
|
||||||
might be a new source of dangling-pointer bugs,
|
dangling-pointer bugs. Capturing a pointer by value doesn't cause a deep
|
||||||
particularly if a lambda escapes the current scope.</li>
|
copy, so it often has the same lifetime issues as capture by reference.
|
||||||
|
This is especially confusing when capturing 'this' by value, since the use
|
||||||
|
of 'this' is often implicit.</li>
|
||||||
|
|
||||||
<li>It's possible for use of lambdas to get out of
|
<li>It's possible for use of lambdas to get out of
|
||||||
hand; very long nested anonymous functions can make
|
hand; very long nested anonymous functions can make
|
||||||
code harder to understand.</li>
|
code harder to understand.</li>
|
||||||
|
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -3634,10 +3558,8 @@ wrapper <code>std::function</code>.
|
||||||
<ul>
|
<ul>
|
||||||
<li>Use lambda expressions where appropriate, with formatting as
|
<li>Use lambda expressions where appropriate, with formatting as
|
||||||
described <a href="#Formatting_Lambda_Expressions">below</a>.</li>
|
described <a href="#Formatting_Lambda_Expressions">below</a>.</li>
|
||||||
<li>Use default captures judiciously, when it aids readability.
|
<li>Prefer explicit captures if the lambda may escape the current scope.
|
||||||
In particular, prefer to write lambda captures explicitly when
|
For example, instead of:
|
||||||
capturing <code>this</code> or if the lambda will escape the
|
|
||||||
current scope. For example, instead of:
|
|
||||||
<pre class="badcode">{
|
<pre class="badcode">{
|
||||||
Foo foo;
|
Foo foo;
|
||||||
...
|
...
|
||||||
|
@ -3662,6 +3584,15 @@ prefer to write:
|
||||||
// reference.
|
// reference.
|
||||||
</pre>
|
</pre>
|
||||||
</li>
|
</li>
|
||||||
|
<li>Use default capture by reference ([&]) only when the
|
||||||
|
lifetime of the lambda is obviously shorter than any potential
|
||||||
|
captures.
|
||||||
|
</li>
|
||||||
|
<li>Use default capture by value ([=]) only as a means of binding a
|
||||||
|
few variables for a short lambda, where the set of captured
|
||||||
|
variables is obvious at a glance. Prefer not to write long or
|
||||||
|
complex lambdas with default capture by value.
|
||||||
|
</li>
|
||||||
<li>Keep unnamed lambdas short. If a lambda body is more than
|
<li>Keep unnamed lambdas short. If a lambda body is more than
|
||||||
maybe five lines long, prefer to give the lambda a name, or to
|
maybe five lines long, prefer to give the lambda a name, or to
|
||||||
use a named function instead of a lambda.</li>
|
use a named function instead of a lambda.</li>
|
||||||
|
@ -4029,10 +3960,59 @@ guide, the following C++11 features may not be used:</p>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<h3 id="Nonstandard_Extensions">Nonstandard Extensions</h3>
|
||||||
|
|
||||||
|
<div class="summary">
|
||||||
|
<p>Nonstandard extensions to C++ may not be used unless otherwise specified.</p>
|
||||||
|
</div>
|
||||||
|
<div class="stylebody">
|
||||||
|
<div class="definition">
|
||||||
|
<p>Compilers support various extensions that are not part of standard C++. Such
|
||||||
|
extensions include GCC's <code>__attribute__</code>, intrinsic functions such
|
||||||
|
as <code>__builtin_prefetch</code>, designated initializers (e.g.
|
||||||
|
<code>Foo f = {.field = 3}</code>), inline assembly, <code>__COUNTER__</code>,
|
||||||
|
<code>__PRETTY_FUNCTION__</code>, compound statement expressions (e.g.
|
||||||
|
<code>foo = ({ int x; Bar(&x); x })</code>, and the <code>a?:b</code>
|
||||||
|
syntax.</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pros">
|
||||||
|
<ul>
|
||||||
|
<li>Nonstandard extensions may provide useful features that do not exist
|
||||||
|
in standard C++. For example, some people think that designated
|
||||||
|
initializers are more readable than standard C++ features like
|
||||||
|
constructors.</li>
|
||||||
|
<li>Important performance guidance to the compiler can only be specified
|
||||||
|
using extensions.</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="cons">
|
||||||
|
<ul>
|
||||||
|
<li>Nonstandard extensions do not work in all compilers. Use of nonstandard
|
||||||
|
extensions reduces portability of code.</li>
|
||||||
|
<li>Even if they are supported in all targeted compilers, the extensions
|
||||||
|
are often not well-specified, and there may be subtle behavior differences
|
||||||
|
between compilers.</li>
|
||||||
|
<li>Nonstandard extensions add to the language features that a reader must
|
||||||
|
know to understand the code.</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="decision">
|
||||||
|
<p>Do not use nonstandard extensions. You may use portability wrappers that
|
||||||
|
are implemented using nonstandard extensions, so long as those wrappers
|
||||||
|
|
||||||
|
are provided by a designated project-wide
|
||||||
|
portability header.</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<h3 id="Aliases">Aliases</h3>
|
<h3 id="Aliases">Aliases</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
|
@ -4141,7 +4121,7 @@ the rules are the rules.</p>
|
||||||
<h3 id="General_Naming_Rules">General Naming Rules</h3>
|
<h3 id="General_Naming_Rules">General Naming Rules</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Names should be descriptive; eschew abbreviation.</p>
|
<p>Names should be descriptive; avoid abbreviation.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -4299,14 +4279,6 @@ the trailing underscores that data members in classes have.</p>
|
||||||
Classes</a> for a discussion of when to use a struct
|
Classes</a> for a discussion of when to use a struct
|
||||||
versus a class.</p>
|
versus a class.</p>
|
||||||
|
|
||||||
<h4 class="stylepoint_subsection">Global Variables</h4>
|
|
||||||
|
|
||||||
<p>There are no special requirements for global
|
|
||||||
variables, which should be rare in any case, but if you
|
|
||||||
use one, consider prefixing it with <code>g_</code> or
|
|
||||||
some other marker to easily distinguish it from local
|
|
||||||
variables.</p>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Constant_Names">Constant Names</h3>
|
<h3 id="Constant_Names">Constant Names</h3>
|
||||||
|
@ -4375,9 +4347,10 @@ of the class's member variables.</p>
|
||||||
<h3 id="Namespace_Names">Namespace Names</h3>
|
<h3 id="Namespace_Names">Namespace Names</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
Namespace names are all lower-case. Top-level
|
Namespace names are all lower-case. Top-level namespace names are
|
||||||
namespace names are based on the project name
|
based on the project name
|
||||||
.
|
. Avoid collisions
|
||||||
|
between nested namespaces and well-known top-level namespaces.
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -4397,21 +4370,28 @@ as variable names. Code inside the namespace seldom needs to
|
||||||
mention the namespace name, so there's usually no particular need
|
mention the namespace name, so there's usually no particular need
|
||||||
for abbreviation anyway.</p>
|
for abbreviation anyway.</p>
|
||||||
|
|
||||||
<p>Naming conventions for nested namespaces are at the discretion
|
<p>Avoid nested namespaces that match well-known top-level
|
||||||
of the team owning the enclosing namespace. If a nested namespace
|
namespaces. Collisions between namespace names can lead to surprising
|
||||||
is used to group related functions in a single header file, consider basing
|
build breaks because of name lookup rules. In particular, do not
|
||||||
its name on the header name, e.g. namespace <code>foo::bar</code>
|
create any nested <code>std</code> namespaces. Prefer unique project
|
||||||
for functions defined in the header file <code>bar.h</code>.
|
identifiers
|
||||||
If the nested namespace is being used to distinguish implementation
|
(<code>websearch::index</code>, <code>websearch::index_util</code>)
|
||||||
details from user-facing declarations, one common choice is
|
over collision-prone names like <code>websearch::util</code>.</p>
|
||||||
<code>internal</code>.</p>
|
|
||||||
|
<p>For <code>internal</code> namespaces, be wary of other code being
|
||||||
|
added to the same <code>internal</code> namespace causing a collision
|
||||||
|
(internal helpers within a team tend to be related and may lead to
|
||||||
|
collisions). In such a situation, using the filename to make a unique
|
||||||
|
internal name is helpful
|
||||||
|
(<code>websearch::index::frobber_internal</code> for use
|
||||||
|
in <code>frobber.h</code>)</p>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Enumerator_Names">Enumerator Names</h3>
|
<h3 id="Enumerator_Names">Enumerator Names</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Enumerators should be named <i>either</i> like
|
<p>Enumerators (for both scoped and unscoped enums) should be named <i>either</i> like
|
||||||
<a href="#Constant_Names">constants</a> or like
|
<a href="#Constant_Names">constants</a> or like
|
||||||
<a href="#Macro_Names">macros</a>: either <code>kEnumName</code> or
|
<a href="#Macro_Names">macros</a>: either <code>kEnumName</code> or
|
||||||
<code>ENUM_NAME</code>.</p>
|
<code>ENUM_NAME</code>.</p>
|
||||||
|
@ -4537,9 +4517,13 @@ comment and what style you use where.</p>
|
||||||
<h3 id="File_Comments">File Comments</h3>
|
<h3 id="File_Comments">File Comments</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p> Start each file with license
|
<p>Start each file with license boilerplate.</p>
|
||||||
boilerplate, followed by a description of its
|
|
||||||
contents.</p>
|
<p>File comments describe the contents of a file. If a file declares,
|
||||||
|
implements, or tests exactly one abstraction that is documented by a comment
|
||||||
|
at the point of declaration, file comments are not required. All other files
|
||||||
|
must have file comments.</p>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -4559,30 +4543,22 @@ author line, consider deleting the author line.</p>
|
||||||
|
|
||||||
<h4 class="stylepoint_subsection">File Contents</h4>
|
<h4 class="stylepoint_subsection">File Contents</h4>
|
||||||
|
|
||||||
<p>Every file should have a comment at the top describing
|
<p>If a <code>.h</code> declares multiple abstractions, the file-level comment
|
||||||
its contents, unless the specific conditions described below apply.</p>
|
should broadly describe the contents of the file, and how the abstractions are
|
||||||
|
related. A 1 or 2 sentence file-level comment may be sufficient. The detailed
|
||||||
<p>A file-level comment in a <code>.h</code> should broadly describe
|
documentation about individual abstractions belongs with those abstractions,
|
||||||
the contents of the file. If the file declares multiple abstractions, the
|
not at the file level.</p>
|
||||||
file-level comment should document how they are related. A 1 or 2 sentence
|
|
||||||
file-level comment may be sufficient. The detailed documentation about
|
|
||||||
individual abstractions belongs with those abstractions, not at the file
|
|
||||||
level.</p>
|
|
||||||
|
|
||||||
<p>Do not duplicate comments in both the <code>.h</code> and the
|
<p>Do not duplicate comments in both the <code>.h</code> and the
|
||||||
<code>.cc</code>. Duplicated comments diverge.</p>
|
<code>.cc</code>. Duplicated comments diverge.</p>
|
||||||
|
|
||||||
<p>A file-level comment may be omitted if the file declares, implements, or
|
</div>
|
||||||
tests exactly one abstraction that is documented by a comment at the point
|
|
||||||
of declaration.</p><p>
|
|
||||||
|
|
||||||
</p></div>
|
|
||||||
|
|
||||||
<h3 id="Class_Comments">Class Comments</h3>
|
<h3 id="Class_Comments">Class Comments</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Every class definition should have an accompanying comment
|
<p>Every non-obvious class declaration should have an accompanying
|
||||||
that describes what it is for and how it should be used.</p>
|
comment that describes what it is for and how it should be used.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
@ -4609,28 +4585,34 @@ surrounding multithreaded use.</p>
|
||||||
<p>The class comment is often a good place for a small example code snippet
|
<p>The class comment is often a good place for a small example code snippet
|
||||||
demonstrating a simple and focused usage of the class.</p>
|
demonstrating a simple and focused usage of the class.</p>
|
||||||
|
|
||||||
|
<p>When sufficiently separated (e.g. <code>.h</code> and <code>.cc</code>
|
||||||
|
files), comments describing the use of the class should go together with its
|
||||||
|
interface definition; comments about the class operation and implementation
|
||||||
|
should accompany the implementation of the class's methods.</p>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Function_Comments">Function Comments</h3>
|
<h3 id="Function_Comments">Function Comments</h3>
|
||||||
|
|
||||||
<div class="summary">
|
<div class="summary">
|
||||||
<p>Declaration comments describe use of the function; comments
|
<p>Declaration comments describe use of the function (when it is
|
||||||
at the definition of a function describe operation.</p>
|
non-obvious); comments at the definition of a function describe
|
||||||
|
operation.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
|
||||||
<h4 class="stylepoint_subsection">Function Declarations</h4>
|
<h4 class="stylepoint_subsection">Function Declarations</h4>
|
||||||
|
|
||||||
<p>Every function declaration should have comments
|
<p>Almost every function declaration should have comments immediately
|
||||||
immediately preceding it that describe what the function
|
preceding it that describe what the function does and how to use
|
||||||
does and how to use it. These comments should be
|
it. These comments may be omitted only if the function is simple and
|
||||||
descriptive ("Opens the file") rather than imperative
|
obvious (e.g. simple accessors for obvious properties of the
|
||||||
("Open the file"); the comment describes the function, it
|
class). These comments should be descriptive ("Opens the file")
|
||||||
does not tell the function what to do. In general, these
|
rather than imperative ("Open the file"); the comment describes the
|
||||||
comments do not describe how the function performs its
|
function, it does not tell the function what to do. In general, these
|
||||||
task. Instead, that should be left to comments in the
|
comments do not describe how the function performs its task. Instead,
|
||||||
function definition.</p>
|
that should be left to comments in the function definition.</p>
|
||||||
|
|
||||||
<p>Types of things to mention in comments at the function
|
<p>Types of things to mention in comments at the function
|
||||||
declaration:</p>
|
declaration:</p>
|
||||||
|
@ -4733,25 +4715,28 @@ is used for. In certain cases, more comments are required.</p>
|
||||||
|
|
||||||
<h4 class="stylepoint_subsection">Class Data Members</h4>
|
<h4 class="stylepoint_subsection">Class Data Members</h4>
|
||||||
|
|
||||||
<p>Each class data member (also called an instance
|
<p>The purpose of each class data member (also called an instance
|
||||||
variable or member variable) should have a comment
|
variable or member variable) must be clear. If there are any
|
||||||
describing what it is used for. If the variable can take
|
invariants (special values, relationships between members, lifetime
|
||||||
sentinel values with special meanings, such as a null
|
requirements) not clearly expressed by the type and name, they must be
|
||||||
pointer or -1, document this. For example:</p>
|
commented. However, if the type and name suffice (<code>int
|
||||||
|
num_events_;</code>), no comment is needed.</p>
|
||||||
|
|
||||||
|
<p>In particular, add comments to describe the existence and meaning
|
||||||
|
of sentinel values, such as nullptr or -1, when they are not
|
||||||
|
obvious. For example:</p>
|
||||||
|
|
||||||
<pre>private:
|
<pre>private:
|
||||||
// Keeps track of the total number of entries in the table.
|
// Used to bounds-check table accesses. -1 means
|
||||||
// Used to ensure we do not go over the limit. -1 means
|
|
||||||
// that we don't yet know how many entries the table has.
|
// that we don't yet know how many entries the table has.
|
||||||
int num_total_entries_;
|
int num_total_entries_;
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
<h4 class="stylepoint_subsection">Global Variables</h4>
|
<h4 class="stylepoint_subsection">Global Variables</h4>
|
||||||
|
|
||||||
<p>As with data members, all global variables should have
|
<p>All global variables should have a comment describing what they
|
||||||
a comment describing what they are and what they are used
|
are, what they are used for, and (if unclear) why it needs to be
|
||||||
for. For example:</p>
|
global. For example:</p>
|
||||||
|
|
||||||
<pre>// The total number of tests cases that we run through in this regression test.
|
<pre>// The total number of tests cases that we run through in this regression test.
|
||||||
const int kNumTestCases = 6;
|
const int kNumTestCases = 6;
|
||||||
|
@ -5226,10 +5211,10 @@ function call.</p>
|
||||||
|
|
||||||
<pre>class Foo {
|
<pre>class Foo {
|
||||||
public:
|
public:
|
||||||
Foo(Foo&&) = default;
|
Foo(Foo&&);
|
||||||
Foo(const Foo&) = default;
|
Foo(const Foo&);
|
||||||
Foo& operator=(Foo&&) = default;
|
Foo& operator=(Foo&&);
|
||||||
Foo& operator=(const Foo&) = default;
|
Foo& operator=(const Foo&);
|
||||||
};
|
};
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
|
@ -5254,6 +5239,12 @@ void Circle::Rotate(double /*radians*/) {}
|
||||||
void Circle::Rotate(double) {}
|
void Circle::Rotate(double) {}
|
||||||
</pre>
|
</pre>
|
||||||
|
|
||||||
|
<p>Attributes, and macros that expand to attributes, appear at the very
|
||||||
|
beginning of the function declaration or definition, before the
|
||||||
|
return type:</p>
|
||||||
|
<pre>MUST_USE_RESULT bool IsOK();
|
||||||
|
</pre>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<h3 id="Formatting_Lambda_Expressions">Lambda Expressions</h3>
|
<h3 id="Formatting_Lambda_Expressions">Lambda Expressions</h3>
|
||||||
|
@ -5790,7 +5781,7 @@ beginning of the line.</p>
|
||||||
|
|
||||||
<div class="stylebody">
|
<div class="stylebody">
|
||||||
|
|
||||||
<p>The basic format for a class declaration (lacking the
|
<p>The basic format for a class definition (lacking the
|
||||||
comments, see <a href="#Class_Comments">Class
|
comments, see <a href="#Class_Comments">Class
|
||||||
Comments</a> for a discussion of what comments are
|
Comments</a> for a discussion of what comments are
|
||||||
needed) is:</p>
|
needed) is:</p>
|
||||||
|
@ -6210,6 +6201,6 @@ more interesting. Have fun!</p>
|
||||||
<hr>
|
<hr>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div></body></html></div>
|
</body></html></div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user