改变基于模板参数的引用类型。

huangapple go评论69阅读模式
英文:

Change type of reference based on template parameter

问题

现在我大致有这段代码。
```cpp
Type1 myVarWithAVeryLongName1 = new Type1(); // 实际上是一个指针链,但这样可以明白意思
Type2 myVarWithAVeryLongName2 = new Type2();

template<bool usesType2>
void func() {
    //auto& myVar = usesType2 ? myVarWithAVeryLongName2 : myVarWithAVeryLongName1; // 三元表达式不能返回不同类型
    /*if constexpr (usesType2) {
        auto& myVar = myVarWithAVeryLongName2;
    } else {
        auto& myVar = myVarWithAVeryLongName1;
    } // 将`myVar`放到了作用域外
    */
    auto& myVar = ?;
    // …
}
英文:

Right now I have roughly this code.

Type1 myVarWithAVeryLongName1 = new Type1(); // Really a chain of pointers, but this gets the point across
Type2 myVarWithAVeryLongName2 = new Type2();

template<bool usesType2>
void func() {
    //auto& myVar = usesType2 ? myVarWithAVeryLongName2 : myVarWithAVeryLongName1; // A ternart expression can't return different types
    /*if constexpr (usesType2) {
        auto& myVar = myVarWithAVeryLongName2;
    } else {
        auto& myVar = myVarWithAVeryLongName1;
    } // Puts `myVar` out of scope
    */
    auto& myVar = ?;
    // …
}

I want to do a very similar operation on both myVarWithAVeryLongName1 and myVarWithAVeryLongName2. Since the operation takes lots of code and Type1 and Type2 are so similar, I can save ~300 lines of code by making one function and resolving the few differences with if constexpr blocks. However, the two variables are a lot to type out, so I alias them with auto& myVar = myVarWithAVeryLongName1; and use myVar for the rest of the function. Is there any way to do this?

答案1

得分: 2

以下是您要翻译的内容:

#include <type_traits>

using Type1 = int;
using Type2 = double;

Type1* myVarWithAVeryLongName1 = new Type1();
Type2* myVarWithAVeryLongName2 = new Type2();

template<bool usesType2>
void func() {
    using type = std::conditional_t<usesType2, Type2, Type1>;
    auto& myVar =
        []() -> type& {
            if constexpr(usesType2) {
                return *myVarWithAVeryLongName2;
            } else {
                return *myVarWithAVeryLongName1;
            }
        }();
    // …
}

int main() {
    func<true>();
    func<false>();
}

希望这有所帮助。

英文:

You can use an immediately invoked lambda and std::conditional_t:

#include &lt;type_traits&gt;

using Type1 = int;
using Type2 = double;

Type1* myVarWithAVeryLongName1 = new Type1();
Type2* myVarWithAVeryLongName2 = new Type2();

template&lt;bool usesType2&gt;
void func() {
    using type = std::conditional_t&lt;usesType2, Type2, Type1&gt;;
    auto&amp; myVar =
        []() -&gt; type&amp; {
            if constexpr(usesType2) {
                return *myVarWithAVeryLongName2;
            } else {
                return *myVarWithAVeryLongName1;
            }
        }();
    // …
}

int main() {
    func&lt;true&gt;();
    func&lt;false&gt;();
}

huangapple
  • 本文由 发表于 2023年5月22日 03:48:51
  • 转载请务必保留本文链接:https://go.coder-hub.com/76301655.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定