首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >列表集合addRange多项

列表集合addRange多项
EN

Stack Overflow用户
提问于 2019-06-15 11:50:49
回答 3查看 1.1K关注 0票数 1

到目前为止,我正在使用下面的代码在列表中添加新的项目。

代码语言:javascript
复制
 mItems.Add(new TableItemsClass() { Description = sqlReader["Name"].ToString(),InventoryTransTempID = Convert.ToInt32(sqlReader["InventoryTransTempID"]) });

如何使用相同的方法来使用AddRange

代码语言:javascript
复制
 mItems.AddRange(new TableItemsClass() { Description = sqlReader["Name"].ToString(),InventoryTransTempID = Convert.ToInt32(sqlReader["InventoryTransTempID"]) });

使用上面的代码,我将接受以下错误:

CS1503 Argument 1: cannot convert from 'WiOrderAndroid.TableItemsClass to System.Collections.Generic.IEnumerable<WiOrderAndroid.TableItemsClass>

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-06-15 11:57:37

AddRange期望IEnumerable作为参数,但是要将T传递给它,只需传递一个列表:

代码语言:javascript
复制
mItems.AddRange(
    new List<TableItemsClass> 
    { 
        new TableItemsClass() 
        { 
          Description = "descr",
          InventoryTransTempID == 1
        },
        new TableItemsClass() 
        { 
           Description = "descr",
           InventoryTransTempID == 2
        } 
    });
票数 0
EN

Stack Overflow用户

发布于 2019-06-15 11:57:45

AddRange接受一个IEnumerable,而不是一个元素。处理此类方案的一种方法是将项目包装在数组中:

代码语言:javascript
复制
mItems.AddRange(new TableItemsClass[] {new TableItemsClass() { Description = sqlReader["Name"].ToString(),InventoryTransTempID = Convert.ToInt32(sqlReader["InventoryTransTempID"]) }});
票数 0
EN

Stack Overflow用户

发布于 2019-06-15 12:00:23

AddRange用于添加多个可枚举类型的项。new TableItemsClass()是一个对象。所以Add会起作用的。如果有类似于List<TableItemsClass>()的这些对象的集合,则可以使用AddRange()方法。

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

https://stackoverflow.com/questions/56610110

复制
相关文章

相似问题

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