• List泛型Add后,所有值都是最后一次Add的结果 解决方法


    public List<VoucherEntryEntity> AnalyseVoucherEntry(DataTable voucherentry)
            {

                VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
                List<VoucherEntryEntity> listVoucherEntity = new List<VoucherEntryEntity>();
                for (int i = 0; i < voucherentry.Rows.Count;i++ )
                {
                    voucherentryentity.FBrNo = voucherentry.Rows[i]["FBrNo"].ToString();
                    voucherentryentity.FExplanation = voucherentry.Rows[i]["FExplanation"].ToString();
                    voucherentryentity.FAccountID = Convert.ToInt32(voucherentry.Rows[i]["FAccountID"]);
                    voucherentryentity.FDetailID = Convert.ToInt32(voucherentry.Rows[i]["FDetailID"]);
                    voucherentryentity.FCurrencyID = Convert.ToInt32(voucherentry.Rows[i]["FCurrencyID"]);
                    voucherentryentity.FExchangeRate = float.Parse(voucherentry.Rows[i]["FExchangeRate"].ToString());
                    voucherentryentity.FDC = Convert.ToInt32(voucherentry.Rows[i]["FDC"]);
                    voucherentryentity.FAmountFor = Convert.ToDecimal(voucherentry.Rows[i]["FAmountFor"]);
                    voucherentryentity.FAmount = Convert.ToDecimal(voucherentry.Rows[i]["FAmount"]);
                    voucherentryentity.FQuantity = float.Parse(voucherentry.Rows[i]["FQuantity"].ToString());
                    voucherentryentity.FMeasureUnitID = Convert.ToInt32(voucherentry.Rows[i]["FMeasureUnitID"]);
                    voucherentryentity.FUnitPrice = float.Parse(voucherentry.Rows[i]["FUnitPrice"].ToString());
                    voucherentryentity.FInternalInd = voucherentry.Rows[i]["FInternalInd"].ToString();
                    voucherentryentity.FAccountID2 = Convert.ToInt32(voucherentry.Rows[i]["FAccountID2"]);
                    voucherentryentity.FSettleTypeID = Convert.ToInt32(voucherentry.Rows[i]["FSettleTypeID"]);
                    voucherentryentity.FSettleNo = voucherentry.Rows[i]["FSettleNo"].ToString();
                    voucherentryentity.FTransNo = voucherentry.Rows[i]["FTransNo"].ToString();
                    voucherentryentity.FCashFlowItem = Convert.ToInt32(voucherentry.Rows[i]["FCashFlowItem"]);
                    voucherentryentity.FTaskID = Convert.ToInt32(voucherentry.Rows[i]["FTaskID"]);
                    voucherentryentity.FResourceID = Convert.ToInt32(voucherentry.Rows[i]["FResourceID"]);
                    listVoucherEntity.Add(voucherentryentity);
                }
                return listVoucherEntity;
            }

    添加多条数据时,所有的值都是最后一次的结果。

    原来在.net中,list 在ADD时,每次保留一个它的引用,所以要把VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
    放到for循环中去才可以避免ADD后的值不会重复,也就是每循环一次,VoucherEntryEntity 就要new 一次.

    public List<VoucherEntryEntity> AnalyseVoucherEntry(DataTable voucherentry)
            {

                
                List<VoucherEntryEntity> listVoucherEntity = new List<VoucherEntryEntity>();
                for (int i = 0; i < voucherentry.Rows.Count;i++ )
                {

                    VoucherEntryEntity voucherentryentity = new VoucherEntryEntity();
                    voucherentryentity.FBrNo = voucherentry.Rows[i]["FBrNo"].ToString();
                    voucherentryentity.FExplanation = voucherentry.Rows[i]["FExplanation"].ToString();
                    voucherentryentity.FAccountID = Convert.ToInt32(voucherentry.Rows[i]["FAccountID"]);
                    voucherentryentity.FDetailID = Convert.ToInt32(voucherentry.Rows[i]["FDetailID"]);
                    voucherentryentity.FCurrencyID = Convert.ToInt32(voucherentry.Rows[i]["FCurrencyID"]);
                    voucherentryentity.FExchangeRate = float.Parse(voucherentry.Rows[i]["FExchangeRate"].ToString());
                    voucherentryentity.FDC = Convert.ToInt32(voucherentry.Rows[i]["FDC"]);
                    voucherentryentity.FAmountFor = Convert.ToDecimal(voucherentry.Rows[i]["FAmountFor"]);
                    voucherentryentity.FAmount = Convert.ToDecimal(voucherentry.Rows[i]["FAmount"]);
                    voucherentryentity.FQuantity = float.Parse(voucherentry.Rows[i]["FQuantity"].ToString());
                    voucherentryentity.FMeasureUnitID = Convert.ToInt32(voucherentry.Rows[i]["FMeasureUnitID"]);
                    voucherentryentity.FUnitPrice = float.Parse(voucherentry.Rows[i]["FUnitPrice"].ToString());
                    voucherentryentity.FInternalInd = voucherentry.Rows[i]["FInternalInd"].ToString();
                    voucherentryentity.FAccountID2 = Convert.ToInt32(voucherentry.Rows[i]["FAccountID2"]);
                    voucherentryentity.FSettleTypeID = Convert.ToInt32(voucherentry.Rows[i]["FSettleTypeID"]);
                    voucherentryentity.FSettleNo = voucherentry.Rows[i]["FSettleNo"].ToString();
                    voucherentryentity.FTransNo = voucherentry.Rows[i]["FTransNo"].ToString();
                    voucherentryentity.FCashFlowItem = Convert.ToInt32(voucherentry.Rows[i]["FCashFlowItem"]);
                    voucherentryentity.FTaskID = Convert.ToInt32(voucherentry.Rows[i]["FTaskID"]);
                    voucherentryentity.FResourceID = Convert.ToInt32(voucherentry.Rows[i]["FResourceID"]);
                    listVoucherEntity.Add(voucherentryentity);
                }
                return listVoucherEntity;
            }

  • 相关阅读:
    LeetCode 189. Rotate Array
    LeetCode 965. Univalued Binary Tree
    LeetCode 111. Minimum Depth of Binary Tree
    LeetCode 104. Maximum Depth of Binary Tree
    Windows下MySQL的安装与配置
    LeetCode 58. Length of Last Word
    LeetCode 41. First Missing Positive
    LeetCode 283. Move Zeroes
    《蚂蚁金服11.11:支付宝和蚂蚁花呗的技术架构及实践》读后感
    删除docker下的镜像
  • 原文地址:https://www.cnblogs.com/glj1203/p/1865871.html
Copyright © 2020-2023  润新知