首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >问题CASTing与IEnumerator GetEnumerator()

问题CASTing与IEnumerator GetEnumerator()
EN

Stack Overflow用户
提问于 2015-10-01 15:09:26
回答 1查看 143关注 0票数 0

我并不完全理解CASTing和序列化的所有复杂性,下面的代码在第二个对象的GetEnumerator()代码块中产生了一个强制转换错误,我遇到了问题。

无论是在解决这一问题方面,还是在更好地理解这一点方面,任何和所有的帮助都将受到极大的赞赏。提前谢谢。

代码语言:javascript
复制
[Serializable]
public class DBFieldMap
{
    public String fieldName { get; set; }
    public String fieldValue { get; set; }
    public DBFieldMap() { }
    public DBFieldMap(String fname, String fvalue)
    {
        fieldName = fname;
        fieldValue = fvalue;
    }
    public IEnumerator GetEnumerator()
    {
        return (IEnumerator)this;
    }
}

第二对象

代码语言:javascript
复制
[Serializable]
public class MappedSQLFields : Dictionary<String, DBFieldMap>
{
    public MappedSQLFields()
    {
        this.Add("clinicianstatus", new DBFieldMap());
        this.Add("researcherstatus", new DBFieldMap());
        this.Add("patientcarestatus", new DBFieldMap());
        this.Add("managerstatus", new DBFieldMap());
        this.Add("locationid", new DBFieldMap());
        this.Add("managerid", new DBFieldMap());


    }
    public IEnumerator GetEnumerator()
    {
        return (IEnumerator)this; ==>Error message  here is -Unable to cast object of type MappedSQLFields System.Collections.IEnumerator System.InvalidCastException

    }
    public MappedSQLFields(SerializationInfo info, StreamingContext context)
        : base(info, context)
    {
  }

主要目标:

代码语言:javascript
复制
public Audience()
{
...
    Dictionary<String, String> fields = new Dictionary<String, String>()
       {
        {"_locationid",""},
        {"_managerid",""},
        {"_clinicianstatus",""},
        {"_managerstatus",""},
        {"_patientcarestatus",""},
        {"_researcherstatus",""},
       };

    private void loadCriteria()
    { 
        //Load values into Dictionary
        foreach (KeyValuePair<String,DBFieldMap> item in audienceSQLMap) ==>Error in stack starts here
        {
            this.fields["_"+ item.Key] = item.Value.fieldValue; 
        }
    }
 }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-01 15:12:46

好的,DBFieldMap没有实现IEnumerable,所以我可以理解为什么那个转换会失败。

其次,MappedSQLFields已经通过继承Dictionary<String, DBFieldMap>实现了IEnumerable<KeyValuePair<String, DBFieldMap>>,所以我不知道为什么您觉得需要再次实现它。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32890991

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档