141

如果我有:

void MyMethod(Object obj) {   ...   }

我怎样才能obj转换成它的实际类型?

4

9 回答 9

221

如果您知道实际类型,那么只需:

SomeType typed = (SomeType)obj;
typed.MyFunction();

如果您不知道实际类型,那么:不是真的,不。您将不得不使用以下之一:

  • 反射
  • 实现一个众所周知的接口
  • 动态的

例如:

// reflection
obj.GetType().GetMethod("MyFunction").Invoke(obj, null);

// interface
IFoo foo = (IFoo)obj; // where SomeType : IFoo and IFoo declares MyFunction
foo.MyFunction();

// dynamic
dynamic d = obj;
d.MyFunction();
于 2012-09-02T07:22:54.030 回答
46

我不认为你可以(不是没有反射),你也应该为你的函数提供一个类型:

void MyMethod(Object obj, Type t)
{
    var convertedObject = Convert.ChangeType(obj, t);
    ...
}

更新

这可能对您有用:

void MyMethod(Object obj)
{
    if (obj is A)
    {
        A a = obj as A;
        ...
    } 
    else if (obj is B)
    {
        B b = obj as B;
        ...
    }
}
于 2012-09-02T07:25:20.173 回答
4

怎么样

JsonConvert.DeserializeObject<SomeType>(object.ToString());
于 2019-11-11T10:41:43.667 回答
1

如果您的MyFunction()方法仅在一个类(及其后代)中定义,请尝试

void MyMethod(Object obj) 
{
    var o = obj as MyClass;
    if (o != null)
        o.MyFunction();
}

如果您有大量不相关的类定义要调用的函数,则应该定义一个接口并让您的类定义该接口:

interface IMyInterface
{
    void MyFunction();
}

void MyMethod(Object obj) 
{
    var o = obj as IMyInterface;
    if (o != null)
        o.MyFunction();
}
于 2012-09-02T07:31:12.680 回答
1

就我而言,AutoMapper 运行良好。

AutoMapper 无需任何显式配置即可映射到动态对象/从动态对象映射:

public class Foo {
    public int Bar { get; set; }
    public int Baz { get; set; }
}
dynamic foo = new MyDynamicObject();
foo.Bar = 5;
foo.Baz = 6;

Mapper.Initialize(cfg => {});

var result = Mapper.Map<Foo>(foo);
result.Bar.ShouldEqual(5);
result.Baz.ShouldEqual(6);

dynamic foo2 = Mapper.Map<MyDynamicObject>(result);
foo2.Bar.ShouldEqual(5);
foo2.Baz.ShouldEqual(6);

同样,您可以直接从字典映射到对象,AutoMapper 会将键与属性名称对齐。

更多信息https://github.com/AutoMapper/AutoMapper/wiki/Dynamic-and-ExpandoObject-Mapping

于 2017-05-10T06:37:46.790 回答
0

如果您现在将类型转换为它的真实类型,例如它是从名为 abc 的类定向的。您可以通过这种方式调用您的函数:

(abc)(obj)).MyFunction();

如果您不知道该功能,它可以以不同的方式完成。总是不容易。但是你可以通过它的签名以某种方式找到它。如果这是你的情况,你应该让我们知道。

于 2012-09-02T08:11:50.023 回答
0

如果可能有多种类型,则方法本身不知道要转换的类型,但调用者知道,您可能会使用如下内容:

void TheObliviousHelperMethod<T>(object obj) {
    (T)obj.ThatClassMethodYouWantedToInvoke();
}

// Meanwhile, where the method is called:
TheObliviousHelperMethod<ActualType>(obj);

可以使用where括号后的关键字添加对类型的限制。

于 2020-09-04T23:54:52.040 回答
-2
Implement an interface to call your function in your method
interface IMyInterface
{
 void MyinterfaceMethod();
}

IMyInterface MyObj = obj as IMyInterface;
if ( MyObj != null)
{
MyMethod(IMyInterface MyObj );
}
于 2012-09-02T07:26:54.177 回答
-5

转换为实际类型很容易:

void MyMethod(Object obj) {
    ActualType actualyType = (ActualType)obj;
}
于 2012-09-02T07:22:46.183 回答