草庐IT

null_object

全部标签

c# - 为什么可空值序列的 Linq-to-Objects 总和本身可以为空?

像往常一样,int?表示System.Nullable(或System.Nullable`1[System.Int32])。假设您在内存中有一个IEnumerable(例如List),我们称它为seq;然后你可以找到它的总和:varseqSum=seq.Sum();当然这会转到扩展方法重载int?IEnumerable.Sum()(documentation)这实际上是System.Linq.Enumerable上的静态方法.但是,该方法永远不会返回null,那么为什么返回类型声明为Nullable?即使在seq的情况下是一个空集合,或者更一般地说,是一个所有元素都是null的集合类型

c# - MVC 3.0 ModelBinder bindingContext.ValueProvider.GetValue(key) 在集合中绑定(bind)时返回 null

我是使用自定义ModelBinders的新手,我一直在四处寻找,但找不到与此特定案例相关的任何帖子。我有一个像这样的实体:publicclassDynamicData{publicIListDynamicDataItems{get;set;}}在View中,我将其绑定(bind)如下:@Html.EditorFor(model=>model.DynamicDataItems);我在类DynamicDataItems中有特殊信息,我想以特定方式检索这些信息,因此我创建了自己的模型绑定(bind)器。publicclassDynamicDataItemBinder:IModelBinder

c# - Code Contracts 是否未能发现 Nullable<T>.HasValue 和 null 之间的明显关系?

我正在尝试将代码契约应用到我的代码中,但我遇到了一个令人费解的问题。这段代码不符合契约(Contract),但除非我真的很厚,否则我希望它能够轻松分析id在返回时必须有一个值if(id==null)thrownewInvalidOperationException(string.Format("{0}'{1}'doesnotyethaveanidentity",typeof(T).Name,entity));returnid.Value; 最佳答案 我已经弄清了这个行为的真相,这不是CodeContract的错。我在ILSpy中打开

c# - "Object cannot be cast from DBNull to other types"

当我的网站执行到以下代码时,它会崩溃并出现如下异常:System.InvalidCastException:ObjectcannotbecastfromDBNulltoothertypes.为了简洁起见,我只展示了相关代码(我得到的是一个4000+LOC文件)。if(dr["STAGE"]isDBNull){dto.Stage=1;//Thisisthelinethrowingtheexception,accordingtostacktrace}else{dto.Stage=Convert.ToInt32(dr["STAGE"]);}这里,dr是一个DataRow对象,它是对数据库的查

c# - 具有 null 属性的嵌套属性的动态 linq 排序

我正在使用我从here获得的这个动态linqorderby函数.这适用于嵌套属性,所以我可以这样做:varresult=data.OrderBy("SomeProperty.NestedProperty");问题是,如果SomeProperty为空,则在NestedProperty上执行OrderBy会抛出臭名昭著的“对象引用未设置为对象的实例”。我的猜测是我需要自定义以下行来处理异常:expr=Expression.Property(expr,pi);//OrLambdaExpressionlambda=Expression.Lambda(delegateType,expr,arg)

c# - 检查 null 线程安全吗?

我有一些代码在新线程上抛出异常,我需要在主线程上确认和处理这些异常。为实现这一点,我通过使用保存抛出异常的字段在线程之间共享状态。我的问题是我是否需要在检查null时使用锁,就像我在下面的代码示例中所做的那样?publicclassMyClass{readonlyobject_exceptionLock=newobject();Exception_exception;publicMyClass(){Task.Run(()=>{while(CheckIsExceptionNull()){//Thisconditionalwillreturntrueif'somethinghasgonew

c# - 删除可选相关实体时如何将 FK 更新为 null

我是EF的新手,在删除我的对象方面遇到了一些困难。我的两个对象和关联的DbContext如下所示:publicclassContext:DbContext{publicContext():base(){}publicDbSetPersons{get;set;}publicDbSetVehicles{get;set;}}publicclassPerson{publicintPersonID{get;set;}publicstringName{get;set;}}publicclassVehicle{publicintVehicleID{get;set;}publicint?PersonI

c# - 从 json 转换为 List<object> 导致异常

所以这是我的问题,我有一个API设置,它以JSON字符串格式从Azure存储表返回结果:[{"CustID":"f3b6.....0768bec","Title":"Timesheet","CalendarID":"AAMkADE5ZDViNmIyLWU3N2.....pVolcdmAABY3IuJAAA=","PartitionKey":"Project","RowKey":"94a6.....29a4f34","Timestamp":"2018-09-02T11:24:57.1838388+03:00","ETag":"W/\"datetime'2018-09-02T08%3A24

c# - 如果使用可为空的 int 变量,LINQ 返回 0 个结果,如果使用 "null",则返回准确的结果

我有一个名为“test”的表,它只有1列,“NullableInt”(可为空的int类型)记录为:1、2、nullint?nullableInt=null;vart=db.tests.Where(x=>x.NullableInt==null).ToList();//returns1recordvart2=db.tests.Where(x=>x.NullableInt==nullableInt).ToList();//returns0records出于某种原因,t2返回0条记录,即使它使用了值为null的“nullableInt”变量,就像t与“null”进行比较一样如有任何帮助,我们将

c# - SQL - 将 NULL 插入 DateTime

我有一个表,我在其中将Datetime添加到某些列中。我使用存储过程将值插入表中。在存储过程中,我有一些变量接受null以插入到表中。我的问题是,当我尝试向表列中插入一个空值时,我在该列中得到了1900-01-01。我该怎么做而不是这个默认值在列中仅插入NULL??这是我的SP:CREATEPROCEDUREdbo.Insert@InserIDint,@InsertDateDatetime=null,ASInsertintoTables(InsertID,InsertDate)Values(@InsertID,@InsertDate)我这样做是为了分配一个空值:System.Data.