<bdo id='4AJ9F'></bdo><ul id='4AJ9F'></ul>
    <i id='4AJ9F'><tr id='4AJ9F'><dt id='4AJ9F'><q id='4AJ9F'><span id='4AJ9F'><b id='4AJ9F'><form id='4AJ9F'><ins id='4AJ9F'></ins><ul id='4AJ9F'></ul><sub id='4AJ9F'></sub></form><legend id='4AJ9F'></legend><bdo id='4AJ9F'><pre id='4AJ9F'><center id='4AJ9F'></center></pre></bdo></b><th id='4AJ9F'></th></span></q></dt></tr></i><div id='4AJ9F'><tfoot id='4AJ9F'></tfoot><dl id='4AJ9F'><fieldset id='4AJ9F'></fieldset></dl></div>
    <tfoot id='4AJ9F'></tfoot>
    <legend id='4AJ9F'><style id='4AJ9F'><dir id='4AJ9F'><q id='4AJ9F'></q></dir></style></legend>

    1. <small id='4AJ9F'></small><noframes id='4AJ9F'>

        默认模板参数偏特化

        时间:2023-05-25
        <i id='wsKHF'><tr id='wsKHF'><dt id='wsKHF'><q id='wsKHF'><span id='wsKHF'><b id='wsKHF'><form id='wsKHF'><ins id='wsKHF'></ins><ul id='wsKHF'></ul><sub id='wsKHF'></sub></form><legend id='wsKHF'></legend><bdo id='wsKHF'><pre id='wsKHF'><center id='wsKHF'></center></pre></bdo></b><th id='wsKHF'></th></span></q></dt></tr></i><div id='wsKHF'><tfoot id='wsKHF'></tfoot><dl id='wsKHF'><fieldset id='wsKHF'></fieldset></dl></div>

        <small id='wsKHF'></small><noframes id='wsKHF'>

          • <bdo id='wsKHF'></bdo><ul id='wsKHF'></ul>

                <tfoot id='wsKHF'></tfoot>
                  <tbody id='wsKHF'></tbody>
              • <legend id='wsKHF'><style id='wsKHF'><dir id='wsKHF'><q id='wsKHF'></q></dir></style></legend>
                  本文介绍了默认模板参数偏特化的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  限时送ChatGPT账号..

                  请向我解释为什么下面的代码能够完美运行.我很困惑.

                  Please explain to me why the following piece of code complies and works perfectly. I am very confused.

                  #include<iostream>
                  template<class A = int, class B=double>
                  class Base
                  {};
                  
                  template<class B>
                  class Base <int, B>
                  {
                  public:
                    Base()
                    {
                       std::cout<<"it works!!!!!
                  ";
                    }
                  };
                  
                  int main()
                  {
                    Base<> base; // it prints "it works!!!!!"
                    return 0;
                  }
                  

                  不应该属于模板类Base的泛化形式吗?

                  Shouldn't it fall into the generalized form of the template class Base?

                  推荐答案

                  默认参数适用于特化——事实上,特化必须接受(可以这么说)基模板的默认参数.尝试在专业化中指定默认值:

                  The default argument applies to the specialization -- and, in fact, a specialization must accept (so to speak) the base template's default argument(s). Attempting to specify a default in the specialization:

                  template<class A = int, class B=double>
                  class Base
                  {};
                  
                  template<class B=char>
                  // ...
                  

                  ...是一个错误.

                  同样,如果我们改变特化,使它的特化是针对一个类型other而不是基础模板提供的默认值:

                  Likewise, if we change the specialization so that its specialization is for a type other than the default provided by the base template:

                  template<class A = int, class B=double>
                  class Base
                  {};
                  
                  template<class B>
                  class Base <char, B>
                  

                  ...然后将选择基本模板.

                  ...then the base template will be chosen.

                  所以,发生的事情是:首先选择模板参数的类型.在这种情况下(在实例化时没有指定类型),两种类型都基于基本模板中指定的默认模板参数.

                  So, what's happening is this: first the types for the template arguments are chosen. In this case (no type specified at instantiation), both types are based on the default template arguments specified in the base template.

                  然后(作为一个基本上独立的步骤)它对适合这些参数类型的所有模板执行重载决议的模拟.与通常的重载解析一样,显式指定的类型优先于隐式指定的类型,因此您的专业化(显式指定 int)优先于基本模板(指定 int代码> 隐式).

                  Then (as a basically separate step) it carries out an analog of overload resolution on all templates that fit those argument types. As usual for overload resolution, a type that's specified explicitly is preferred over one that's specified implicitly, so your specialization (which specified int explicitly) is preferred over the base template (which specified int implicitly).

                  这篇关于默认模板参数偏特化的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:模板元编程 - 使用 Enum Hack 和 Static Const 的区别 下一篇:C++ 模板类型名迭代器

                  相关文章

                  最新文章

                1. <legend id='o9I0f'><style id='o9I0f'><dir id='o9I0f'><q id='o9I0f'></q></dir></style></legend>
                    <i id='o9I0f'><tr id='o9I0f'><dt id='o9I0f'><q id='o9I0f'><span id='o9I0f'><b id='o9I0f'><form id='o9I0f'><ins id='o9I0f'></ins><ul id='o9I0f'></ul><sub id='o9I0f'></sub></form><legend id='o9I0f'></legend><bdo id='o9I0f'><pre id='o9I0f'><center id='o9I0f'></center></pre></bdo></b><th id='o9I0f'></th></span></q></dt></tr></i><div id='o9I0f'><tfoot id='o9I0f'></tfoot><dl id='o9I0f'><fieldset id='o9I0f'></fieldset></dl></div>

                      <tfoot id='o9I0f'></tfoot>
                        <bdo id='o9I0f'></bdo><ul id='o9I0f'></ul>

                      <small id='o9I0f'></small><noframes id='o9I0f'>