C# 如何在使用Expando对象时将类型设置为可空

C# 如何在使用Expando对象时将类型设置为可空,c#,.net,dynamic,nullable,expandoobject,C#,.net,Dynamic,Nullable,Expandoobject,我有一个动态类型的集合。我已将双值存储在集合中。对于某些记录,我不会将数据存储到其中。现在,我需要将该类型设置为nullabledouble来执行一些操作。在使用Expando对象时,是否有方法将数据属性类型获取为null ObservableCollection<dynamic> dynamicItems = new ObservableCollection<dynamic>(); for (int j = 1; j <= 4; j++) { dynami

我有一个
动态
类型的集合。我已将双值存储在集合中。对于某些记录,我不会将数据存储到其中。现在,我需要将该类型设置为
nullable
double来执行一些操作。在使用
Expando
对象时,是否有方法将数据属性类型获取为
null

ObservableCollection<dynamic> dynamicItems = new ObservableCollection<dynamic>();
for (int j = 1; j <= 4; j++)
{
    dynamic data = new ExpandoObject();
    if (j == 2)
    {
        // not store the value when j is 2.
    }
    else
    {
        data.colValues = 12.2 * j;                  
    }

    dynamicItems.Add(data);
}
ObservableCollection dynamicItems=新的ObservableCollection();
对于(int j=1;j您可以尝试强制转换为
Double?
,然后检查
colValues==null

   ...
   if (j == 2)
   {
        // not store the value when j is 2.
       data.colValues = new Nullable<Double>(); // or (Double?) null;
   }
   else
   {
       data.colValues = (Double?) (12.2 * j);                  
   }
   ...

   // if colValues exists
   if (null != data.colValues) {
     Double v = data.colValues;
     ... 
   }

为什么不创建一个类来存储这些信息呢?我绑定了这个集合“dynamicItems”对于datagridHi,你能分享一下如何进行一般性的更改吗?@Elavarasan M:第二种方法根本不依赖于
colValues
类型;第一种方法要求
colValues
being
struct
我需要根据类型执行一些操作。但是在添加值时,我没有给出类型。但是当执行时在某些操作中,我需要将colvalues的类型设置为可为null的double。是否有任何选项可以获取此值?谢谢Advance@ElavarasanM:
Double?
(或
Nullable
)可以用作可为null的Double(参见我的第一段代码)好的。但是我不会在存储值时给出它的类型。如果我得到colvalues的类型,它返回的是double。但实际上它是可为null的double,因为我使用了expandoobject,并且在某些情况下没有将值存储到colvalues。如果我得到类型means,我需要作为可为null的double。我的意思是,在运行时,我根据值获取colvalues的类型这意味着它返回了双倍。如果有任何建议,你能分享一下吗。很抱歉给你带来麻烦。
   if (j == 2)
   {
        // not store the value when j is 2. - literally do nothing
   }
   else
   {
       data.colValues = 12.2 * j;                  
   }

   ... 
   // if colValues exists
   if ((data as IDictionary<String, Object>).ContainsKey("colValues")) {
     Double v = data.colValues; // or var v = data.colValues;
     ... 
   }