10

为了反序列化一个 json 对象,我必须为子类定义一个包含一个对象或对象数组的父类。如果检索到一个对象,它必须是一个对象,如果从 json 检索到一个数组,它必须是一个对象数组。

JSON数组对象

{"y":{"x":[{"data":28}, {"data":56}, {"data":89}]}}

JSON 对象

{"y":{"x":{"data":28}}}

y 一次接收 x,另一次接收 x[]。没有这样的条件来确定 y 是否会接收数组或对象。

因此,为了确定我是否收到了一个数组,我正在检查 IsArray() 条件。

我试过

class Y
{
   public X x { get { return System.IsArray() ? new X() : new x[] }; set; }
}

class X
{
   public int data { get; set; }
}
  1. 它不工作。
  2. System.IsArray() 未被识别?
4

4 回答 4

14

首先,数组一个对象。这是一件好事,因为它允许这些功能工作(都假设using System;):

bool IsArray(object o) { return o is Array; }
bool IsArray(object o) { return o.GetType().IsArray; }

其次,如果您想要一个类型可以是XX[]的属性,则该属性的类型需要是object

class Y             
{
   private object _x;
   public object x {
       get { return _x; }
       set
       {
           if (value.GetType != typeof(X) && value.GetType != typeof(X[]))
               throw new ArgumentException("value");
           _x = value;
       }
   }
}

这有点忽略了静态类型的优势,因为您object在运行时使用和检查类型。将属性定义为数组确实要简单得多,即使对于只有一个值的情况也是如此。在这种情况下,它将是一个长度为 1 的数组。

于 2012-04-12T06:38:07.633 回答
6

我一直在使用Json.NET Nuget 包,使用起来非常容易:

  string jsonStr = "{'y':{'x':[{'data':28}, {'data':56}, {'data':89}]}}";
  dynamic jobject = JsonConvert.DeserializeObject(jsonStr);

  bool isArray  = jobject.y.x.Type == JTokenType.Array;
  bool isObject = jobject.y.x.Type == JTokenType.Object;

希望这可以帮助!

于 2014-01-31T20:29:27.820 回答
1

如果您明确声明它是 X 类型,则 Y 类中 X 类型的属性 x 不能是 X 的数组。将其声明为对象将是解决此问题的一种方法。

如果你想检查它是一个数组,我会使用一个支持字段(比如_x),然后你使用该属性的地方做一个检查(typeof(_x) == X[]

不过,这可能会变得混乱,我最好的建议是将属性 x 的类型设置为 X[] 并在集合中确定该值是否是一个数组(如果是这样,只需 set _x = value),或者如果不是将值添加到 X 的空数组

于 2012-04-12T06:29:23.353 回答
0

你可以试试这个...

if (obj.GetType().IsArray)
{
  ...
}

另一种方法是,

if (obj is Array) {
   ...
}
于 2021-03-12T11:48:27.730 回答