jjzjj

circular-reference

全部标签

c# - OOPS 概念 : What is the difference in passing object reference to interface and creating class object in C#?

我有一个类CustomerNew和一个接口(interface)ICustomer:publicclassCustomerNew:ICustomer{publicvoidA(){MessageBox.Show("Classmethod");}voidICustomer.A(){MessageBox.Show("Interfacemethod");}publicvoidB(){MessageBox.Show("ClassMethod");}}publicinterfaceICustomer{voidA();}我对这两行代码很困惑。ICustomerobjnew=newCustomerNe

c# - 添加由多部分命名空间引起的服务引用后 Reference.cs 中的编译错误

我在VisualStudio2010中将第一个“服务引用”添加到客户端项目时遇到了这个奇怪的命名空间问题。如果我的项目的默认命名空间使用两个或多个部分,例如MyCompany.MyApp然后在添加服务引用时创建一个包含命名空间MyCompany.MyApp.ServiceReferenceName的Reference.cs文件,其中包含大量具有完全限定名称的自动生成代码,例如System.SerializableAttribute,System.Runtime.Serialization.DataContractAttribute。Reference.cs文件将充满编译错误,因为编译器

c# - References of References with COM 调用者

这个问题在这里已经有了答案:AddmanagedDLLdependenciedtounmanagedC++project(1个回答)关闭6年前。我有这样一个场景:使用VBA从MSAccess应用程序调用COM调用我们正在构建的C#库,该库引用了Newtonsoft.Jsonv9库使用nuget包,它们自己依赖Newtonsoft.Jsonv6(例如,Microsoft.AspNet.WebApi.Client)当他们尝试使用Newtonsoft.Json(或与我们的C#库引用的版本不同的任何库)时,它自己的黑盒代码中的依赖库会崩溃错误:Couldnotloadfileorassembl

c# - 如何防止自引用表变成循环

这是一个很常见的问题,但我还没有找到我正在寻找的确切问题和答案。我有一个表有一个FK指向它自己的PK,以启用任意深度的层次结构,比如经典的tblEmployee有一个列Manager这是一个FK与PKtblEmployee.EmployeeID.假设在我的应用中,用户任命新员工Alice和Dave,没有经理,因为他们是CEO和总裁。所以tblEmployee.Manager对于这两条记录是NULL。创建新员工鲍勃,爱丽丝担任经理。然后创建Charles,Bob作为他的经理。他们的经理字段包含tblEmployee中另一条记录的主键值。为Alice编辑员工记录,这意味着指定Dave有她的

c# - 同一程序集中的循环引用是一件坏事吗?

假设我在同一个程序集中有以下类publicclassParentClass:IDisposable{publicChildClassChild{get{return_child;}}}publicclassChildClass{publicParentClassParent{get{return_parent;}set{_parent=value;}}publicChildClass(ParentClassparent){Parent=parent;}}如果我错了请纠正我,但这是糟糕的设计。这会导致内存泄漏或其他一些不可预见的问题吗?显然垃圾收集器能够处理suchkindofcircu

c# - 是否可以使用循环引用执行序列化?

因此,我的实体类(用C#编写)遵循父子模型,其中每个子对象都必须有一个Parent属性,在该属性中它保留对其父对象的引用。由于循环引用,此Parent属性会导致对象序列化出现问题。我无法删除对父级的引用,也无法将其标记为XmlIgnore(因为我需要在反序列化XML时读回它)对此有什么想法吗? 最佳答案 XML序列化不支持循环引用,您需要使用XmlIgnore属性从序列化中排除父属性。参见thisblogpost一种在反序列化时维持关系的方法。或者,您可以使用DataContractSerializer而不是XmlSerialize

c# - 使用 Automapper 导致堆栈溢出的循环引用

我正在使用Automapper将我的NHibernate代理对象(DTO)映射到我的CSLA业务对象我正在使用FluentNHibernate创建映射-这工作正常我遇到的问题是Order有一个OrderLines集合,其中每个都有一个对Order的引用。publicclassOrderMapping:ClassMap{publicOrderMapping(){//StandardpropertiesId(x=>x.OrderId);Map(x=>x.OrderDate);Map(x=>x.Address);HasMany(x=>x.OrderLines).KeyColumn("Orde

c# - "Object reference not set to an instance of an object": why can't . NET 显示更多细节?

“对象引用未设置到对象的实例”为什么异常不显示对象引用字段的名称,或者至少不显示它的类型?这可能是.NET中最常见的运行时错误之一。尽管System.Exception有堆栈跟踪,但没有其他有用的详细信息。在一年的时间里,我花了几个小时筛选堆栈跟踪(通常是在我没有编写的代码中),希望有一个来自“.pdb”文件的行号,然后在代码中找到该行,甚至那么该行中的哪个引用为空通常并不明显。拥有引用字段的名称会非常方便。如果System.ArgumentNullException实例可以显示方法参数的名称(“值不能为空。参数名称:值”),那么System.NullReferenceExceptio

c# - DELETE 语句与 Entity Framework 的 SAME TABLE REFERENCE 约束冲突

我有一个带有自引用的表,其中ParentId是ID(PK)的FK。使用EF(代码优先),我建立了如下关系:this.HasOptional(t=>t.ParentValue).WithMany(t=>t.ChildValues).HasForeignKey(t=>t.ParentId);当我尝试删除子项及其父项时,EF向数据库发出的DELETE命令与我预期的顺序不符-它首先尝试删除父项记录。我意识到我在这里有几个选择(我都不喜欢):先删除子记录,进行完整保存/提交,然后删除父记录。考虑到我的模型及其维护逻辑的复杂性,这不是一个选项-我无法在需要时发出多个提交命令。在删除任何内容之前解除

c# - 如何在设计时避免 XAML 代码中出现 "object reference not set to an instance of an object"异常?

我自己设计的wpf用户控件有问题。问题是,当我在我的程序中实现用户控件时,在设计时XAML代码中出现objectreferencenotsettoaninstanceofanobject异常。设计师向我展示了以下信息:atMicrosoft.Expression.Platform.InstanceBuilders.InstanceBuilderOperations.InstantiateType(Typetype,BooleansupportInternal)atMicrosoft.Expression.Platform.InstanceBuilders.ClrObjectInstan