C++ Coding Standards
Book 1
Book 2
Book 3
Book 1
Book 2
Book 3
Book 1
Book 2
Book 3
Book 1
Book 2
Book 3
Home > Computing and Information Technology > Computer programming / software engineering > Programming and scripting languages: general > C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)
C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)

C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)


     0     
5
4
3
2
1



International Edition


X
About the Book

Consistent, high-quality coding standards improve software quality, reduce time-to-market, promote teamwork, eliminate time wasted on inconsequential matters, and simplify maintenance. Now, two of the world's most respected C++ experts distil the rich collective experience of the global C++ community into a set of coding standards that every developer and development team can understand and use as a basis for their own coding standards. The authors cover virtually every facet of C++ programming: design and coding style, functions, operators, class design, inheritance, construction/destruction, copying, assignment, namespaces, modules, templates, exceptions, STL containers and algorithms, and more. Each standard is described concisely, with practical examples. From type definition to error handling, this book presents C++ best practices, including some that have only recently been identified and standardised-techniques you may not know even if you've used C++ for years. Along the way, you'll find answers to questions like What's worth standardising--and what isn't? What are the best ways to code for scalability? What are the elements of a rational error handling policy? How (and why) do you avoid unnecessary initialisation, cyclic, and definitional dependencies? When (and how) should you use static and dynamic polymorphism together? How do you practice "safe" overriding? When should you provide a no-fail swap? Why and how should you prevent exceptions from propagating across module boundaries? Why shouldn't you write namespace declarations or directives in a header file? Why should you use STL vector and string instead of arrays? How do you choose the right STL search or sort algorithm? What rules should you follow to ensure type-safe code? Whether you're working alone or with others, C++ Coding Standards will help you write cleaner code--and write it faster, with fewer hassles and less frustration.

Table of Contents:
Preface. 1. Organizational and Policy Issues.     Don't sweat the small stuff. (Or: Know what not to standardize.).     Compile cleanly at high warning levels.     Use an automated build system.     Use a version control system.     Invest in code reviews. 2. Design Style.     Give one entity one cohesive responsibility.     Correctness, simplicity, and clarity come first.     Know when and how to code for scalability.     Don't optimize prematurely.     Don't pessimize prematurely.     Minimize global and shared data.     Hide information.     Know when and how to code for concurrency.     Ensure resources are owned by objects. Use explicit RAII and smart pointers. 3. Coding Style.     Prefer compile- and link-time errors to run-time errors.     Use const proactively.     Avoid macros.     Avoid magic numbers.     Declare variables as locally as possible.     Always initialize variables.     Avoid long functions. Avoid deep nesting.     Avoid initialization dependencies across compilation units.     Minimize definitional dependencies. Avoid cyclic dependencies.     Make header files self-sufficient.     Always write internal #include guards. Never write external #include guards. 4. Functions and Operators.     Take parameters appropriately by value, (smart) pointer, or reference.     Preserve natural semantics for overloaded operators.     Prefer the canonical forms of arithmetic and assignment operators.     Prefer the canonical form of ++ and --. Prefer calling the prefix forms.     Consider overloading to avoid implicit type conversions.     Avoid overloading &&, ||, or , (comma).     Don't write code that depends on the order of evaluation of functionarguments. 5. Class Design and Inheritance.     Be clear what kind of class you're writing.     Prefer minimal classes to monolithic classes.     Prefer composition to inheritance.     Avoid inheriting from classes that were not designed to be base classes.     Prefer providing abstract interfaces.     Public inheritance is substitutability.     Inherit, not to reuse, but to be reused.     Practice safe overriding.     Consider making virtual functions nonpublic, and public functions nonvirtual.     Avoid providing implicit conversions.     Make data members private, except in behaviorless aggregates (C-stylestructs).     Don't give away your internals.     Pimpl judiciously.     Prefer writing nonmember nonfriend functions.     Always provide new and delete together.     If you provide any class-specific new, provide all of the standard forms (plain, in-place, and nothrow). 6. Construction, Destruction, and Copying.     Define and initialize member variables in the same order.     Prefer initialization to assignment in constructors.     Avoid calling virtual functions in constructors and destructors.     Make base class destructors public and virtual, or protected and nonvirtual.     Destructors, deallocation, and swap never fail.     Copy and destroy consistently.     Explicitly enable or disable copying.     Avoid slicing. Consider Clone instead of copying in base classes.     Prefer the canonical form of assignment.     Whenever it makes sense, provide a no-fail swap (and provide it correctly). 7. Namespaces and Modules.     Keep a type and its nonmember function interface in the same namespace.     Keep types and functions in separate namespaces unless they're specifically intended to work together.     Don't write namespace usings in a header file or before an #include.     Avoid allocating and deallocating memory in different modules.     Don't define entities with linkage in a header file.     Don't allow exceptions to propagate across module boundaries.     Use sufficiently portable types in a module's interface. 8. Templates and Genericity.     Blend static and dynamic polymorphism judiciously.     Customize intentionally and explicitly.     Don't specialize function templates.     Don't write unintentionally nongeneric code. 9. Error Handling and Exceptions.     Assert liberally to document internal assumptions and invariants.     Establish a rational error handling policy, and follow it strictly.     Distinguish between errors and non-errors.      Design and write error-safe code.     Prefer to use exceptions to report errors.     Throw by value, catch by reference.     Report, handle, and translate errors appropriately.     Avoid exception specifications. 10. STL: Containers.     Use vector by default. Otherwise, choose an appropriate container.     Use vector and string instead of arrays.     Use vector (and string::c_str) to exchange data with non-C++ APIs.     Store only values and smart pointers in containers.     Prefer push_back to other ways of expanding a sequence.     Prefer range operations to single-element operations.     Use the accepted idioms to really shrink capacity and really erase elements. 11. STL: Algorithms.     Use a checked STL implementation.     Prefer algorithm calls to handwritten loops.     Use the right STL search algorithm.     Use the right STL sort algorithm.     Make predicates pure functions.     Prefer function objects over functions as algorithm and comparer arguments.     Write function objects correctly. 12. Type Safety.     Avoid type switching; prefer polymorphism.     Rely on types, not on representations.     Avoid using reinterpret_cast.     Avoid using static_cast on pointers.     Avoid casting away const.     Don't use C-style casts.     Don't memcpy or memcmp non-PODs.     Don't use unions to reinterpret representation.     Don't use varargs (ellipsis).     Don't use invalid objects. Don't use unsafe functions.     Don't treat arrays polymorphically. Bibliography. Summary of Summaries. Index.

About the Author :
Herb Sutter is the author of three highly acclaimed books, Exceptional C++ Style, Exceptional C++, and More Exceptional C++ (Addison-Wesley). He chairs the ISO C++ standards committee, and is contributing editor and columnist for C/C++ Users Journal. As a software architect for Microsoft, Sutter leads the design of C++ language extensions for .NET programming. Andrei Alexandrescu is the author of the award-winning book Modern C++ Design (Addison-Wesley, 2001) and is a columnist for C/C++ Users Journal.


Best Sellers


Product Details
  • ISBN-13: 9780321113580
  • Publisher: Pearson Education (US)
  • Publisher Imprint: Addison-Wesley Educational Publishers Inc
  • Height: 234 mm
  • No of Pages: 240
  • Series Title: C++ In-Depth Series
  • Sub Title: 101 Rules, Guidelines, and Best Practices
  • Width: 194 mm
  • ISBN-10: 0321113586
  • Publisher Date: 11 Nov 2004
  • Binding: Paperback
  • Language: English
  • Returnable: Y
  • Spine Width: 10 mm
  • Weight: 440 gr


Similar Products

Add Photo
Add Photo

Customer Reviews

REVIEWS      0     
Click Here To Be The First to Review this Product
C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)
Pearson Education (US) -
C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)
Writing guidlines
We want to publish your review, so please:
  • keep your review on the product. Review's that defame author's character will be rejected.
  • Keep your review focused on the product.
  • Avoid writing about customer service. contact us instead if you have issue requiring immediate attention.
  • Refrain from mentioning competitors or the specific price you paid for the product.
  • Do not include any personally identifiable information, such as full names.

C++ Coding Standards: 101 Rules, Guidelines, and Best Practices(C++ In-Depth Series)

Required fields are marked with *

Review Title*
Review
    Add Photo Add up to 6 photos
    Would you recommend this product to a friend?
    Tag this Book Read more
    Does your review contain spoilers?
    What type of reader best describes you?
    I agree to the terms & conditions
    You may receive emails regarding this submission. Any emails will include the ability to opt-out of future communications.

    CUSTOMER RATINGS AND REVIEWS AND QUESTIONS AND ANSWERS TERMS OF USE

    These Terms of Use govern your conduct associated with the Customer Ratings and Reviews and/or Questions and Answers service offered by Bookswagon (the "CRR Service").


    By submitting any content to Bookswagon, you guarantee that:
    • You are the sole author and owner of the intellectual property rights in the content;
    • All "moral rights" that you may have in such content have been voluntarily waived by you;
    • All content that you post is accurate;
    • You are at least 13 years old;
    • Use of the content you supply does not violate these Terms of Use and will not cause injury to any person or entity.
    You further agree that you may not submit any content:
    • That is known by you to be false, inaccurate or misleading;
    • That infringes any third party's copyright, patent, trademark, trade secret or other proprietary rights or rights of publicity or privacy;
    • That violates any law, statute, ordinance or regulation (including, but not limited to, those governing, consumer protection, unfair competition, anti-discrimination or false advertising);
    • That is, or may reasonably be considered to be, defamatory, libelous, hateful, racially or religiously biased or offensive, unlawfully threatening or unlawfully harassing to any individual, partnership or corporation;
    • For which you were compensated or granted any consideration by any unapproved third party;
    • That includes any information that references other websites, addresses, email addresses, contact information or phone numbers;
    • That contains any computer viruses, worms or other potentially damaging computer programs or files.
    You agree to indemnify and hold Bookswagon (and its officers, directors, agents, subsidiaries, joint ventures, employees and third-party service providers, including but not limited to Bazaarvoice, Inc.), harmless from all claims, demands, and damages (actual and consequential) of every kind and nature, known and unknown including reasonable attorneys' fees, arising out of a breach of your representations and warranties set forth above, or your violation of any law or the rights of a third party.


    For any content that you submit, you grant Bookswagon a perpetual, irrevocable, royalty-free, transferable right and license to use, copy, modify, delete in its entirety, adapt, publish, translate, create derivative works from and/or sell, transfer, and/or distribute such content and/or incorporate such content into any form, medium or technology throughout the world without compensation to you. Additionally,  Bookswagon may transfer or share any personal information that you submit with its third-party service providers, including but not limited to Bazaarvoice, Inc. in accordance with  Privacy Policy


    All content that you submit may be used at Bookswagon's sole discretion. Bookswagon reserves the right to change, condense, withhold publication, remove or delete any content on Bookswagon's website that Bookswagon deems, in its sole discretion, to violate the content guidelines or any other provision of these Terms of Use.  Bookswagon does not guarantee that you will have any recourse through Bookswagon to edit or delete any content you have submitted. Ratings and written comments are generally posted within two to four business days. However, Bookswagon reserves the right to remove or to refuse to post any submission to the extent authorized by law. You acknowledge that you, not Bookswagon, are responsible for the contents of your submission. None of the content that you submit shall be subject to any obligation of confidence on the part of Bookswagon, its agents, subsidiaries, affiliates, partners or third party service providers (including but not limited to Bazaarvoice, Inc.)and their respective directors, officers and employees.

    Accept

    Fresh on the Shelf


    Inspired by your browsing history


    Your review has been submitted!

    You've already reviewed this product!