首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在C#预测中总结结果

在C#预测中总结结果
EN

Stack Overflow用户
提问于 2021-10-26 15:05:39
回答 2查看 103关注 0票数 0

我有一个使用foreach遍历列表的对象,并返回要访问的对象的值。

例如,根据情况,对象返回一个count = 10

我需要总结所有这些记录的值​​,我正在尝试如下,但它没有返回任何内容。

如果删除+=而只保留=,则只检索第一条记录。

我如何总结所有的记录?

代码语言:javascript
复制
public decimal? ValesDisponiveis
{
    get
    {
        decimal? informacaoRetorno = null;

        if (ValeCreditos != null)
        {
            foreach (ValeCredito vale in ValeCreditos)
            {
                informacaoRetorno += vale.ValesDisponiveis;
            }
        }
        return informacaoRetorno;
    }
} 
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-10-26 15:11:54

问题是:

代码语言:javascript
复制
decimal? informacaoRetorno = null;

相反,请使用:

代码语言:javascript
复制
decimal? informacaoRetorno = 0;

或者在这种情况下,最好不使用空,因为初始化时使用0:

代码语言:javascript
复制
decimal informacaoRetorno = 0;

编辑

如注释中所述,如果仍然希望null作为有效结果,如果IEnumerable为null,则仍然可以执行以下操作:

代码语言:javascript
复制
if (ValeCreditos == null)
        return null;
    
return ValeCreditors.Sum(x => x.ValesDisponiveis);

如果ValesDisponiveis已经具有正确的基类型。

票数 6
EN

Stack Overflow用户

发布于 2021-10-26 15:24:03

假设您想返回null,如果没有要加和的项(例如,当ValeCreditos为空时),则应该检查HasValue

代码语言:javascript
复制
public decimal? ValesDisponiveis
{
    get
    {
        decimal? informacaoRetorno = null;

        if (ValeCreditos != null)
        {
            foreach (ValeCredito vale in ValeCreditos)
            {
                if (informacaoRetorno.HasValue) // business as usual: just add
                    informacaoRetorno += vale.ValesDisponiveis;
                else // null + value == null, that's why we assign
                    informacaoRetorno = vale.ValesDisponiveis;
            }
        }
        return informacaoRetorno;
    }
}

此代码返回null on null或空ValeCreditos,否则返回项之和。

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

https://stackoverflow.com/questions/69725579

复制
相关文章

相似问题

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