mirror of
https://github.com/isocpp/CppCoreGuidelines.git
synced 2024-03-22 13:30:58 +08:00
Merge pull request #796 from severinmeyer/C-Typos
Fix typos in section C: Classes and class hierarchies
This commit is contained in:
commit
7741b8689e
|
@ -3513,8 +3513,8 @@ Class rule summary:
|
||||||
* [C.4: Make a function a member only if it needs direct access to the representation of a class](#Rc-member)
|
* [C.4: Make a function a member only if it needs direct access to the representation of a class](#Rc-member)
|
||||||
* [C.5: Place helper functions in the same namespace as the class they support](#Rc-helper)
|
* [C.5: Place helper functions in the same namespace as the class they support](#Rc-helper)
|
||||||
* [C.7: Don't define a class or enum and declare a variable of its type in the same statement](#Rc-standalone)
|
* [C.7: Don't define a class or enum and declare a variable of its type in the same statement](#Rc-standalone)
|
||||||
* [C.8: use `class` rather that `struct` if any member is non-public](#Rc-class)
|
* [C.8: Use `class` rather than `struct` if any member is non-public](#Rc-class)
|
||||||
* [C.9: minimize exposure of members](#Rc-private)
|
* [C.9: Minimize exposure of members](#Rc-private)
|
||||||
|
|
||||||
Subsections:
|
Subsections:
|
||||||
|
|
||||||
|
@ -3708,7 +3708,7 @@ Mixing a type definition and the definition of another entity in the same declar
|
||||||
|
|
||||||
* Flag if the `}` of a class or enumeration definition is not followed by a `;`. The `;` is missing.
|
* Flag if the `}` of a class or enumeration definition is not followed by a `;`. The `;` is missing.
|
||||||
|
|
||||||
### <a name="Rc-class"></a>C.8: use `class` rather that `struct` if any member is non-public
|
### <a name="Rc-class"></a>C.8: Use `class` rather than `struct` if any member is non-public
|
||||||
|
|
||||||
##### Reason
|
##### Reason
|
||||||
|
|
||||||
|
@ -3731,7 +3731,7 @@ There is nothing wrong with this code as far as the C++ language rules are conce
|
||||||
but nearly everything is wrong from a design perspective.
|
but nearly everything is wrong from a design perspective.
|
||||||
The private data is hidden far from the public data.
|
The private data is hidden far from the public data.
|
||||||
The data is split in different parts of the class declaration.
|
The data is split in different parts of the class declaration.
|
||||||
Different parts of the data has difference access.
|
Different parts of the data have different access.
|
||||||
All of this decreases readability and complicates maintenance.
|
All of this decreases readability and complicates maintenance.
|
||||||
|
|
||||||
##### Note
|
##### Note
|
||||||
|
@ -3742,7 +3742,7 @@ Prefer to place the interface first in a class [see](#Rl-order).
|
||||||
|
|
||||||
Flag classes declared with `struct` if there is a `private` or `public` member.
|
Flag classes declared with `struct` if there is a `private` or `public` member.
|
||||||
|
|
||||||
### <a name="Rc-private"></a>C.9: minimize exposure of members
|
### <a name="Rc-private"></a>C.9: Minimize exposure of members
|
||||||
|
|
||||||
##### Reason
|
##### Reason
|
||||||
|
|
||||||
|
@ -3771,7 +3771,7 @@ A value of regular type can be copied and the result of a copy is an independent
|
||||||
If a concrete type has both `=` and `==`, `a = b` should result in `a == b` being `true`.
|
If a concrete type has both `=` and `==`, `a = b` should result in `a == b` being `true`.
|
||||||
Concrete classes without assignment and equality can be defined, but they are (and should be) rare.
|
Concrete classes without assignment and equality can be defined, but they are (and should be) rare.
|
||||||
The C++ built-in types are regular, and so are standard-library classes, such as `string`, `vector`, and `map`.
|
The C++ built-in types are regular, and so are standard-library classes, such as `string`, `vector`, and `map`.
|
||||||
Concrete types are also often referred to as value types to distinguish them from types uses as part of a hierarchy.
|
Concrete types are also often referred to as value types to distinguish them from types used as part of a hierarchy.
|
||||||
|
|
||||||
Concrete type rule summary:
|
Concrete type rule summary:
|
||||||
|
|
||||||
|
@ -3935,7 +3935,7 @@ Other default operations rules:
|
||||||
|
|
||||||
## <a name="SS-defop"></a>C.defop: Default Operations
|
## <a name="SS-defop"></a>C.defop: Default Operations
|
||||||
|
|
||||||
By default, the language supply the default operations with their default semantics.
|
By default, the language supplies the default operations with their default semantics.
|
||||||
However, a programmer can disable or replace these defaults.
|
However, a programmer can disable or replace these defaults.
|
||||||
|
|
||||||
### <a name="Rc-zero"></a>C.20: If you can avoid defining default operations, do
|
### <a name="Rc-zero"></a>C.20: If you can avoid defining default operations, do
|
||||||
|
@ -4542,7 +4542,7 @@ Compilers do not read comments.
|
||||||
|
|
||||||
##### Exception
|
##### Exception
|
||||||
|
|
||||||
If a valid object cannot conveniently be constructed by a constructor [use a factory function](#Rc-factory).
|
If a valid object cannot conveniently be constructed by a constructor, [use a factory function](#Rc-factory).
|
||||||
|
|
||||||
##### Note
|
##### Note
|
||||||
|
|
||||||
|
@ -5512,7 +5512,7 @@ comparisons, `swap`, and `hash`.
|
||||||
|
|
||||||
##### Reason
|
##### Reason
|
||||||
|
|
||||||
The compiler is more likely to get the default semantics right and you cannot implement these function better than the compiler.
|
The compiler is more likely to get the default semantics right and you cannot implement these functions better than the compiler.
|
||||||
|
|
||||||
##### Example
|
##### Example
|
||||||
|
|
||||||
|
@ -6104,7 +6104,7 @@ Readability.
|
||||||
Detection of mistakes.
|
Detection of mistakes.
|
||||||
Writing explicit `virtual`, `override`, or `final` is self-documenting and enables the compiler to catch mismatch of types and/or names between base and derived classes. However, writing more than one of these three is both redundant and a potential source of errors.
|
Writing explicit `virtual`, `override`, or `final` is self-documenting and enables the compiler to catch mismatch of types and/or names between base and derived classes. However, writing more than one of these three is both redundant and a potential source of errors.
|
||||||
|
|
||||||
Use `virtual` only when declaring a new virtual function. Use `override` only when declaring an overrider. Use `final` only when declaring an final overrider. If a base class destructor is declared `virtual`, derived class destructors should neither be declared `virtual` nor `override`.
|
Use `virtual` only when declaring a new virtual function. Use `override` only when declaring an overrider. Use `final` only when declaring a final overrider. If a base class destructor is declared `virtual`, derived class destructors should neither be declared `virtual` nor `override`.
|
||||||
|
|
||||||
##### Example, bad
|
##### Example, bad
|
||||||
|
|
||||||
|
@ -6204,7 +6204,7 @@ The importance of keeping the two kinds of inheritance increases
|
||||||
|
|
||||||
Problems:
|
Problems:
|
||||||
|
|
||||||
* As the hierarchy grows and more data is adder to `Shape`, the constructors gets harder to write and maintain.
|
* As the hierarchy grows and more data is added to `Shape`, the constructors gets harder to write and maintain.
|
||||||
* Why calculate the center for the `Triangle`? we may never us it.
|
* Why calculate the center for the `Triangle`? we may never us it.
|
||||||
* Add a data member to `Shape` (e.g., drawing style or canvas)
|
* Add a data member to `Shape` (e.g., drawing style or canvas)
|
||||||
and all derived classes and all users needs to be reviewed, possibly changes, and probably recompiled.
|
and all derived classes and all users needs to be reviewed, possibly changes, and probably recompiled.
|
||||||
|
@ -6621,7 +6621,7 @@ Too often, such claims are based on conjecture or experience with other language
|
||||||
There are examples where `final` can be important for both logical and performance reasons.
|
There are examples where `final` can be important for both logical and performance reasons.
|
||||||
One example is a performance-critical AST hierarchy in a compiler or language analysis tool.
|
One example is a performance-critical AST hierarchy in a compiler or language analysis tool.
|
||||||
New derived classes are not added every year and only by library implementers.
|
New derived classes are not added every year and only by library implementers.
|
||||||
However, misuses are (or at least has been) far more common.
|
However, misuses are (or at least have been) far more common.
|
||||||
|
|
||||||
##### Enforcement
|
##### Enforcement
|
||||||
|
|
||||||
|
@ -6632,7 +6632,7 @@ Flag uses of `final`.
|
||||||
|
|
||||||
##### Reason
|
##### Reason
|
||||||
|
|
||||||
That can cause confusion: An overrider do not inherit default arguments.
|
That can cause confusion: An overrider does not inherit default arguments.
|
||||||
|
|
||||||
##### Example, bad
|
##### Example, bad
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user