SL: The Standard Library
Using only the bare language, every task is tedious (in any language). Using a suitable library any task can be reasonably simple.
The standard library has steadily grown over the years. Its description in the standard is now larger than that of the language features. So, it is likely that this library section of the guidelines will eventually grow in size to equal or exceed all the rest.
<< ??? We need another level of rule numbering ??? >>
C++ Standard Library component summary:
- SL.con: Containers
- SL.str: String
- SL.io: Iostream
- SL.regex: Regex
- SL.chrono: Time
- SL.C: The C Standard Library
Standard-library rule summary:
- SL.1: Use libraries wherever possible
- SL.2: Prefer the standard library to other libraries
- SL.3: Do not add non-standard entities to namespace
std
- SL.4: Use the standard library in a type-safe manner
- ???
SL.1: Use libraries wherever possible
Reason
Save time. Don't re-invent the wheel. Don't replicate the work of others. Benefit from other people's work when they make improvements. Help other people when you make improvements.
SL.2: Prefer the standard library to other libraries
Reason
More people know the standard library. It is more likely to be stable, well-maintained, and widely available than your own code or most other libraries.
SL.3: Do not add non-standard entities to namespace std
Reason
Adding to std
might change the meaning of otherwise standards conforming code.
Additions to std
might clash with future versions of the standard.
Example
namespace std { // BAD: violates standard
class My_vector {
// . . .
};
}
namespace Foo { // GOOD: user namespace is allowed
class My_vector {
// . . .
};
}
Enforcement
Possible, but messy and likely to cause problems with platforms.
SL.4: Use the standard library in a type-safe manner
Reason
Because, obviously, breaking this rule can lead to undefined behavior, memory corruption, and all kinds of other bad errors.
Note
This is a semi-philosophical meta-rule, which needs many supporting concrete rules. We need it as an umbrella for the more specific rules.
Summary of more specific rules: