草庐IT

object-properties

全部标签

c# - List<T> 和 List<object> 的区别?

既然一切都继承自object,那么List之间有什么区别呢?和List?优点?缺点? 最佳答案 如果您插入int进入List,它将被装箱。如果将其插入List,它不会被装箱(对于任何值类型都是如此,将int替换为类型的名称)。同样,从List中检索值,拆箱会发生,但不会发生List.List是强类型的,List不是(所以你失去了编译时的安全性,并且可能会遇到运行时爆炸)。 关于c#-List和List的区别?,我们在StackOverflow上找到一个类似的问题:

c# - 为什么 .NET 中的每个类都继承自 Object?

我不明白...为什么他们需要一个共同的基地? 最佳答案 这个问题预设了一个谎言。它们不需要通用的基类型。这个选择并不是迫不得已。这是出于为客户提供最佳值(value)的愿望。在设计类型系统或与此相关的任何其他事物时,有时您会到达决策点——您必须决定X或非X。公共(public)基类型或非公共(public)基类型。当发生这种情况时,你权衡X的成本和yield以确定净值,然后你权衡非X的成本和yield以确定净值,然后选择值(value)更高的那个。具有通用基类型的yield大于成本,由此产生的净yield大于没有通用基类型的净yie

C# Auto Property - 这是 'pattern' 最佳实践吗?

我似乎在我的代码中经常使用这种模式,我知道它不再是一个简单的自动属性:publicIListBCSFilters{get;set;}我一直使用的代码是这样的:privateIList_BCSFilters;//////GetsorsetstheBCSfilters.//////TheBCSfilters.publicIListBCSFilters{get{if(_BCSFilters==null){_BCSFilters=newList();}return_BCSFilters;}set{_BCSFilters=value;}}这样我就可以只执行MainClass.BCSFilters

c# - 分页后 TableCell 拆分 : remainder split part loses original cell properties

我有一个关于WPFFlowDocumentTable上的TableCell拆分策略的问题。这是一个简单的代码,可以重现问题:MainWindow.xaml.cs//////InteractionlogicforMainWindow.xaml///publicpartialclassMainWindow:Window{publicMainWindow(){InitializeComponent();vartable=newTable(){BorderThickness=newThickness(1),BorderBrush=Brushes.Black,CellSpacing=0};var

c# - 将 System.Object 作为类型过滤器发出的一般 catch 子句在现实世界中有何影响?

我记得有一次听说抛出System.Exception(或扩展它的对象)以外的某种类型的对象在技术上是合法的CIL,尽管C#没有支持它的功能。所以我有兴趣看到以下C#代码:try{thrownewException();}catch(Exceptionx){try{throw;}catch{Console.Write("yes");}}编译为以下CIL:.try{IL_0000:newobjinstancevoid[mscorlib]System.Exception::.ctor()IL_0005:throw}//end.trycatch[mscorlib]System.Exceptio

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# - "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# - 属性中的单词 "property:"是什么

你能解释一下“property:”这个词是什么意思吗?[property:NotifyParentProperty(true)]publicstringFilename{get;set;} 最佳答案 表示将Attribute应用于属性。在这种特定情况下,它是多余的,可以忽略不计。这种元素定义了AttributeTarget并且在目标可能不明确时最有用,例如目标method和return。VisualStudio还使用AssemblyInfo.cs中的目标assembly生成属性,它是许多项目模板的一部分。更多信息和可能的属性目标列表

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# - 如何在不加载相关记录的情况下判断是否设置了Entity Framework中的Navigation Property

我不确定EF4中的导航属性,所以我想请您解释一下。让我们想象一下这个场景:一个)我的数据库中有两个实体A和B具有N对N(多对多)关系和树表A和B以及一个链接表AB有两个外键。在这种情况下,EF创建一个导航属性,我们称它为X和XReference。B)我的数据库中有两个实体A和B,关系为1到N(一对多)和两个表A和B有一个外键。在这种情况下,EF创建一个导航属性,我们将其称为Y但不是YReference。现在让我们采用场景A和B并尝试找出B中是否有任何A的引用:我的场景代码:一个):boolisA=a.XReference.EntityKey!=null;我不加载B记录(对吗?)乙):b