微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 如何在泛型中使用值类型

@H_404_2@
我有以下代码

public class Class1
{
    void ValueSpecific(string arg)
    {
        // do string stuff
    }
    void ValueSpecific(int arg)
    {
        // do int stuff
    }
    void ValueSpecific(float arg)
    {
        // do float stuff
    }
    void ValueGeneric(string arg)
    {
        // do stuff
        ValueSpecific(arg);
        // do more stuff
    }
    void ValueGeneric(int arg)
    {
        // do stuff
        ValueSpecific(arg);
        // do more stuff
    }
    void ValueGeneric(float arg)
    {
        // do stuff
        ValueSpecific(arg);
        // do more stuff
    }
    void Main(string s,int i,float f)
    {
        ValueGeneric(s);
        ValueGeneric(i);
        ValueGeneric(f);
    }
}

这有效,但ValueGeneric的所有三个重载的机身都是相同的.我想将它们合并为一种方法,它看起来像:

void ValueGeneric<T>(T arg) where T: string,float,int
{
    // do stuff
    ValueSpecific(arg);
    // do more stuff
}

但是,这当然不是有效的C#.
我能想到的最好的是:

void ValueGeneric(object arg)
{
    // Do stuff
    if (arg is int)
    {
        ValueSpecific((int)arg);
    }
    else if (arg is string)
    {
        ValueSpecific((string)arg);
    }
    else if (arg is float)
    {
        ValueSpecific((float)arg);
    }
    else
    {
        Debug.Assert(false,"Invalid type)
    }
    // Do more stuff
}

但这似乎非常不优雅.我很感激任何建议. (虽然我会对任何解决方案感兴趣,但.NET3.5支持解决方案最好,因为我正在使用它.)

@H_404_2@

解决方法

假设你在所有重载之前和之后都做了相同的事情,你可以应用通常的方法来分解代码中的不同之处并对它们进行参数化.唯一改变的是传入的参数以及您对该参数执行的操作.将它们都传递进去.

static void ValueGeneric<T>(T arg,Action<T> action)
{
    // do stuff
    action(arg);
    // do more stuff
}

然后使用适当的操作调用泛型方法(您的ValueSpecific重载将很好地解决自己).

ValueGeneric(s,ValueSpecific);
ValueGeneric(i,ValueSpecific);
ValueGeneric(f,ValueSpecific);
@H_404_2@ @H_404_2@
@H_404_2@
@H_404_2@

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐