• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            健康,快樂(lè),勇敢的寧帥!!

            努力、努力、再努力! 沒(méi)有什么能阻止我對(duì)知識(shí)的渴望。

             

            "C++Templates The Complete Guide"讀書(shū)筆記----Chapter 6

            Using Templates in Practice

            1. Templates challenge the classic compiler-plus-linker model. Therefore there are different approaches to organize template code: the inclusion model, explicit instantiation, and the separation model
            Most C and C++ programmers organize their nontemplate code largely as follows:
            1) Classes and other types are entirely placed in header files.
            2) For global variables and (noninline) functions, only a declaration is put in a header file, and the definition goes into a so-called dot-C file.
            The works well: It makes the needed type definition easily available throughout the program and avoids duplicate definition errors on variables and functions from the linker.
            With the convention in mind, we declare the template in a header file:
            #ifndef?MYFIRST_HPP
            #define?MYFIRST_HPP

            //?declaration?of?template
            template?<typename?T>?
            void?print_typeof?(T?const&);

            #endif?//?MYFIRST_HPP
            The implementation of the function is placed in a dot-C file:
            #include?<iostream>
            #include?
            <typeinfo>
            #include?
            "myfirst.hpp"

            //?implementation/definition?of?template
            template?<typename?T>
            void?print_typeof?(T?const&?x)
            {
            ????std::cout?
            <<?typeid(x).name()?<<?std::endl;
            }
            Finally, we use the template in another dot-C file, into which our template declaration is #include:
            #include?"myfirst.hpp"

            //?use?of?the?template
            int?main()
            {
            ????
            double?ice?=?3.0;
            ????print_typeof(ice);??
            //?call?function?template?for?type?double
            }

            A C++ compiler will most likely accept this program without any problems,but the linker will probably report an error, implying that there is no definition of the function print_typeof().
            In order for a template to be? instantiated, the compiler must know which definition should be instantiated and for what template arguments it should be instantiated. Unfortunately, these two pieces of information are in files that are compiled separatedly. Therefore, when our compiler sees the call to print_typeof() but has no definition in sight to instantiate this function for double, it just assumes that such a definition is provided elsewhere and creates a reference(for the linker to resolve,linker) to that definition. On the other hand, when the compiler processes the file myfirst.cpp, it has no indication at that point that it must instantiate the template definition it contains for specific arguments.

            The Inclusion Model
            Rewrite the header-file, including template definition.
            #ifndef?MYFIRST_HPP
            #define?MYFIRST_HPP


            #include?
            <iostream>
            #include?
            <typeinfo>

            //?declaration?of?template
            template?<typename?T>?
            void?print_typeof?(T?const&
            );

            //?implementation/definition?of?template

            template?<typename?T>
            void?print_typeof?(T?const&?x)
            {
            ????std::cout?
            <<?typeid(x).name()?<<
            ?std::endl;
            }


            #endif?//?MYFIRST_HPP
            disadvantage: the cost is not the result of size of the template definition itself, but the result of the fact that we must also include the header used by the definition of our template-in the case <iostream> and <typeinfo>.\

            Explicit Instantiation
            To avoid above linker error we can add the following file to our program:
            #include?"myfirst.cpp"

            //?explicitly?instantiate?print_typeof()?for?type?double
            template?void?print_typeof<double>(double?const&);
            disadvantage: We must carefully keep track of which entities to instantiate. For large projects this quickly becomes an excessive burden.
            advantage:
            the instantiation can be tuned to the needs of the program.
            The overhead of large header is avoided.
            The source code of template definition can be kept hidden, but then no additional instantiations can be created by a client program.
            Finally, for some applications it can be useful to control the exact location(that is, the object file)of a template instance.

            Separation model

            2. Usually you should use the inclusion model
            3. By separating template code into different header files for declarations and definitions, you can more easily switch between the inclusion model and explicit instantiation
            4. The C++ standard defines a separate compilation model for templates(using the keyword export). It is not yet widely available, however.
            5. To take advantage of precompiled headers, be sure to keep the same order for #include directives.
            6. Debuggin code with templates can be challenging
            7. Template instances may have very long names

            posted on 2006-12-03 12:38 ningfangli 閱讀(177) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            導(dǎo)航

            統(tǒng)計(jì)

            公告

            Dict.CN 在線詞典, 英語(yǔ)學(xué)習(xí), 在線翻譯

            常用鏈接

            留言簿(4)

            隨筆檔案

            文章分類

            文章檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            午夜精品久久久久久| 99久久精品九九亚洲精品| 亚洲狠狠综合久久| 久久无码人妻一区二区三区| 国产欧美一区二区久久| 日韩一区二区久久久久久| 久久久WWW免费人成精品| 亚洲欧美日韩中文久久| 99国产精品久久| 欧美久久综合九色综合| 久久精品国产72国产精福利| 国产午夜电影久久| 亚洲午夜久久久久妓女影院 | 国产精品视频久久久| 波多野结衣中文字幕久久| 久久这里只有精品视频99| 久久天天躁狠狠躁夜夜躁2O2O | 日韩人妻无码精品久久免费一| 久久久久久久久久久久久久 | 伊人久久综在合线亚洲2019| 久久久久四虎国产精品| 88久久精品无码一区二区毛片 | 久久国产美女免费观看精品| 久久久久99精品成人片| 久久国产欧美日韩精品| 国产精品久久久久久影院| 九九久久精品无码专区| 久久香蕉一级毛片| 欧美国产精品久久高清| 三上悠亚久久精品| 久久这里有精品视频| 热re99久久6国产精品免费| 亚洲综合婷婷久久| 久久亚洲国产精品成人AV秋霞| 国产精品丝袜久久久久久不卡| 欧美粉嫩小泬久久久久久久 | 久久精品国产99国产精品| 2019久久久高清456| 99久久精品免费看国产免费| 久久人人爽人人人人爽AV| 国产亚州精品女人久久久久久 |