Advanced C++ Idioms

C++ is a multi-paradigm programming language. This means that there is no single style that is always the right one to use on C++ programs. It all depends on the task at hand. For example, it is completely fine to use C++ only as a structured language, since it has all elements of C and a few more that make structured programming even easier in C++.

The main style of use of the C++ programming language is the classic object oriented style, since it is a style that is easier to reconcile with business practices that have been developed in the previous years.

However, not every project can be done with class object oriented methods. Sometimes it is more productive to use ideas developed in other programming traditions, such as symbolic, functional, and dynamic programming. C++ can also do this, but it needs a little additional thought from the part of the program designer.

The book Advanced C++ Programming Styles and Idioms discusses several idioms that can be successfully used with the C++ programming language.

Many of these idioms are not mainstream, and some of them may not be even acceptable in your organization. Despite this, these idioms could just as well  be the tool of choice for specific problem domains.

Dynamic Features in C++
Among these idioms, are techniques that have been used for a long time in dynamic languages such as Smalltalk and Lisp, such as dynamic dispatching, symbolic computing, and related techniques.

The author, James Coplien, describes how to implement object orientation based on exemplar objects, instead of class based objects. In examplar-based programming, one uses objects as the foundation for creating objects, instead of using classes — as is the normal practice in C++. One of the keys for doing this is to use factory methods to create new objects, instead of using the new keyword, which by definition requires knowledge about the specific class of the created object.

Another strategy is to use Envelope objects, which provide some of the functionality of symbols in a language such as Lisp. Using Envelope objects, one can have automatic memory management through reference counting, and a clean separation between a value and the label that contains it.

Coplien describes how to create more dynamic objects by avoid the classic hierarchy-based approach for classes. He proposes two main solutions for this problem: in the first solution, one creates a shallow hierarchy, where each class has all possible methods that could be implemented by subclasses. In this approach, each object is always crated using the interface of the parent class, and implements only the methods that are of their interest. Subclasses rely on polymorphism to receive the correct messages, and send an error whenever they don’t respond to a particular message.

This technique has the great advantage that clients don’t need to know exactly what class is being called. Also, since the differences between objects is now based only on what methods they respond to, the system is now based on generic methods, rather than on specific classes. Any class can override any method of the top class, which makes it easy to supply dynamic behavior.

The drawback of the previous approach however is that, unless we known all methods that are of interest, the system is subject to recompilation whenever a new method is added to the parent class. To avoid this problem, one can go one step further and create a dynamic dispatch system. In such a system, there is just one method to which an operation descriptor is passed, followed by a number of parameters. In this way, easy concrete subclass can add as many operations as necessary, without any change to the parent class. While such a system may not perform as quickly as a statically defined dispatch method, it is much more flexible, and allows the system to evolve without recompilation.

Finally, the books discuss how to load code dynamically, and therefore avoid linking. The approach works on most systems, however it is machine and compiler-dependent, so it should be used with care when portability is of importance for the system.

Further Reading

Check Advanced C++ Programming Styles and Idioms at Amazon.

Similar Posts:

Similar Posts

920 Comments

  1. Bien plus qu’une robe longue, c’est une affirmation de votre
    style et de votre goût pour l’art et le raffinement.

  2. Les créateurs contemporains réinterprètent ces éléments pour les
    intégrer à des collections modernes, tout en gardant intact l’esprit des années 60.

  3. Si vous voulez porter un déguisement autre qu’un legging pour votre soirée déguisée des eighties ou autres occasions.

  4. My coder is trying to convince me to move to .net from PHP.
    I have always disliked the idea because of the costs.
    But he’s tryiong none the less. I’ve been using WordPress on a variety of websites for
    about a year and am worried about switching to another platform.
    I have heard great things about blogengine.net. Is there a way I
    can import all my wordpress posts into it? Any help would be really appreciated!

    Also visit my blog post: pink salt trick for weight loss

  5. ???? ????? ????????? ? ????????, ? ?????? ???? ??????. ????? ????????, ??? ? ????? ? ?????????????? ??????? ??? ??????? ????????????? ? ???, ??? ???? ??????????. ???????? ? ???, ??? ? ?????? ?????????? ????????, ? ???? ????, ??? ??? ????????, ?????? ??? ???? ????? ??????? ?????? ????? ????????. ?? ??? ??? ?????? ???? ? ?????? ?? ??? ??????????? ???????, ? ????? ??????????? ? ????? ???????????? ???????????? ?????????????.
    ????? ??? ????????? ?????? ? ???? ??????. ???????, ?????????, ???????????? ??? ????????, ????????, ??????? ????????????????, ????? ?????? ?????? ?????????? ????. ??, ???????, ??? ????? ??????? ? ????????????. ? ? ???? ????????? ??????? ? ??????! ??????????, ? ????? ?????? ???????? ???????? ????? ???????? ? ?????????????.
    ??? ??? ????? ??????, ???????????? ??? ????????? ??????? ?? ?????????. ? ???????? ????????? ?????????? ??????, ??? ? ???? ????, ??? ??? ? ??????? ?? ????, ??? ????????? ???? ????? ????????? ? ???????? ??????????. ? ???????, ??????? ??????? ?????? ? ???????? ?????????, ? ?? ?????? ????????? ????? ???? ????????.
    ?????, ? ??? ???? ?????-?? ?????? ???? ? ?????? ?????? ??? ????????? ????? ????? ????????? ???????? ???????? ? ???????????? ???? ????? ??????????? ?? ????? ?????? ? ????????????! ?????????? ?????? ?? ????????.

  6. Fantastic website. Lots of helpful info here. I’m sending it to some pals ans also sharing in delicious.
    And certainly, thank you to your effort!

  7. I have been browsing on-line greater than 3 hours as of
    late, yet I by no means found any fascinating article
    like yours. It is pretty value sufficient for me.
    Personally, if all webmasters and bloggers made excellent content material as you did,
    the net can be a lot more useful than ever before.

  8. I am really inspired with your writing skills as smartly
    as with the layout to your weblog. Is this a paid theme or did you customize it your
    self? Either way keep up the nice high quality
    writing, it is rare to look a nice weblog like this one these
    days..

  9. ???????? ??????? – ??? ???????????? ????????????? ??????????, ??????????????? ??? ?????????? ?????????????? ? ???????????? ??????????, ? ????? ??? ????????????? ???????? ?????. ? ??????? ?? ???????????? ????????? ??? ??????????? ?????????,
    ???????? ??????? ?????????? ???????? ??? ??? ???????? ??????? ????? ???????, ??? ??????????? ???????? ? ???????? ??????? ???????????? ???????????? ? ??????????? ?????. ??? ??????? ??????? ?????????? ?????????????.

  10. ?????????? ??? – ??? ?? ?????? ??????, ?????????? ????????? ? ??????????, ??? ?????? ??????????, ??????? ? ????????? ?????, ??????? ????????????? ? ???????? ?????? ???????. ?? ?????? ???????? ????????? ?? ??????? ? ?????? ?? ??????????? ??????????? ???????????, ?????????? ???? ?????? ?????? ????, ???? ???????????? ?????? ??????????? ?????????. ?? ?????? ?????? ????????? ??? ????????????? ????, ? ???????? ???????? ??????? ???????????? ????????? ???? ? ???????.
    ????? ???????????? ???????????, ???? – ??? ?? ?????? ???????????? ?????????, ?? ? ???????????? ??????, ???????????? ?????????. ???????? ???? ???? ?????? – ??? ????????, ???????????? ?? ????????? ? ?????????, ??????????? ?????????????? ? ??????? ????????. ?????? ??????? – ??? ????????? ???????, ????????? ? ???????????? ???????? ?????, ? ?????? ??? ???????? ????????? ???????? ???????? ?????????. ??? ??????????? ?????? ????

  11. Les robes des années 60 étaient souvent fabriquées à partir de tissus de qualité supérieure comme le coton,
    le lin ou la laine, ce qui leur confère une élégance naturelle.

  12. ?????? ??? ???? – ??? ?? ?????? ???????????? ????????, ?? ? ???????? ?????? ??????????? ?? ???????????? ???????????, ?????, ????????? ? ?????????? ???????????.
    ????? ?????????? ?????? – ????? ????????????? ? ???????????????? ???????? ???? ?????????? ????????. ??????????? ????? ?????????? ??????? ??????????? ?????? ??? ????, ????????????? ?? ???????, ??????????????? ? ??????? ??????????.
    ???????? ?? ??? ???? ????? ????????? ?????? ??? ?????

  13. Elles voulaient des vêtements qui les aideraient à se démarquer,
    et la robe vintage était le moyen idéal d’y parvenir.

  14. Amazing! This blog looks just like my old one!

    It’s on a totally different subject but it has pretty much the same layout and design. Outstanding choice of colors!

  15. ? ???? ????????????? ?????? ???????????? ????????????? ??????? ? ?????, ??????? ???????? ??? ??????????. ?? ???????? ???????? ?? ?????? ???????, ??????? ????? ???????? ?????????????, ? ?????????? ????? ??????????? ?? ????????? ????. ????????????? ? ????, ????? ???? ??????????? ?????????????? ??????????!
    ??????? ?????? ?????? – https://vivod-iz-zapoya-1.ru/

  16. ??????? ??????? ?? ????? ????? ????????? ???? ????????? ? ????? ??? ?????? ????????? ???????? ???????? ? ??????? ? ????????? ????????????. ??????-?????????, ????? ??? AliExpress, Taobao ? ??????, ?????????? ???????? ??????? – ?? ??????????? ? ?????? ?? ??????? ??? ???? ? ?????.
    ????????????????? ?????????? ??????? ??????????? ? ????????? ?????? ??? ? ???????????? ??????. ????? ????? ????? ?????????? ????, ??????? ?? ???????????? ?? ??????? ?????, ???? ?????????? ?????? ????????? ??????? ?? ??????????? ????? ???????? ????. ? ????????? ?????? ??? ?????????????????? ???????? ?? ??????

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.