草庐IT

时序约束

全部标签

c# - CodeDom 泛型类型约束

有没有办法用CodeDom生成类约束。因为当我使用类似的东西时varmethod=newCodeMemberMethod();vargenericParam=newCodeTypeParameter("InterfaceType");genericParam.Constraints.Add("class");method.TypeParameters.Add(genericParam);生成的代码是这样的privateInterfaceTypeGetImpl()whereInterfaceType:@class{}我发现最好的解决方法是在课前使用前导空格genericParam.Con

c# - 更改外键约束命名约定

我们有自己的外部对象命名约定,我需要更改自动生成的外键约束的命名约定。现在它看起来像:FK_dbo.City_dbo.CityType_City_CityTypeId但我希望它被称为City_FKC_CityType。我找到了一个similarquestion这表示您可以手动更改约束的名称。但是,这不适合我,因为我有很多表和外键约束。我找到了一些关于“CustomCodeFirstConventions”的信息,我想知道我是否可以使用它来更改约束的名称,或者是否有任何方法可以实现它?另一种变体是下载EF的源代码,进行更改并使用它,但这是在紧急情况下使用的。附带说明一下,我还想更改主键的

c# - 为什么具有 "where T : class"约束的 Generic<T> 方法接受接口(interface)

我有这个interface:publicinterfaceITestInterface{intTestInt{get;set;}}和这个通用方法(带有T:class约束):publicvoidTest()whereT:class{//DoSomething}这个电话:Test();一切都编译并运行,同时interface不是class(或者是吗?)。为什么会这样?我第一次看到这个是在我的WCF代理类上:publicpartialclassTestServiceClient:System.ServiceModel.ClientBase,TestNamespace.ITestService

c# - 如何枚举 x^2 + y^2 = z^2 - 1(有附加约束)

让我们N是一个数字(10.我必须把它分成3个数字(x,y,z)这样它就可以验证以下条件。1.x我必须找出我可以从一个方法中的给定数字中得到多少组合。我已经尝试如下,但是它花费了很多时间来获得更高的数字并导致超时..intN=Int32.Parse(Console.ReadLine());Listres=newList();//x我的问题:我的解决方案是花时间获得更大的数字(我认为这是for循环),我该如何改进它?是否有更好的方法? 最佳答案 这里有一个枚举三元组的方法,而不是详尽地测试它们,使用这里描述的数论:https://mat

c# - 如何找到违反约束的列?

我有一个强类型数据集,它会为空值抛出此错误,System.Data.ConstraintException:Failedtoenableconstraints.Oneormorerowscontainvaluesviolatingnon-null,unique,orforeign-keyconstraints.atSystem.Data.DataTable.EnableConstraints()atSystem.Data.DataTable.EndLoadData()atSystem.Data.Common.DataAdapter.FillFromReader(DataSetdatas

c# - 接口(interface)作为类型约束和接口(interface)作为参数之间的区别?

如果我想创建一个方法,将IList的实例作为参数(或任何其他接口(interface),但我们以IList为例),我可以创建具有类型约束的泛型方法,例如:publicstaticvoidFoo1(Tlist)whereT:IList{}或者,我可以创建一个直接采用IList参数的方法:publicstaticvoidFoo2(IListlist){}就所有意图和目的而言,这些方法的行为似乎完全相同:ListmyList=newList();Foo1(myList);Foo2(myList);那么我的问题是——这两种方法有什么区别?似乎第二种方法更具可读性;还有其他我应该注意的区别(生成

c# - 为什么在通用序列创建器上使用 Func<> 比使用 new() 约束快得多

考虑以下代码...在我对Windows7x64PC(Inteli73GHz)上的RELEASE(不是调试!)x86构建的测试中,我获得了以下结果:CreateSequence()withnew()took00:00:00.9158071CreateSequence()withcreator()took00:00:00.1383482CreateSequence()withnew()took00:00:00.9198317CreateSequence()withcreator()took00:00:00.1372920CreateSequence()withnew()took00:00:

c# - 空接口(interface) vs 属性,通用约束怎么样?

我有一个类,它使用一个空接口(interface)作为“标记接口(interface)”,像这样:namespaceMyNameSpace{publicinterfaceIMessage{//nothingincommonhere...}publicclassMyMessage:IMessage{publicvoidSendMyMessage(){//Dosomethinghere}}}我在其他一些帖子中以及在MSDN(http://msdn.microsoft.com/en-us/library/ms182128.aspx)上读到,应该避免这种情况,您应该使用自定义属性而不是这个空接

c# - 通用约束和接口(interface)实现/继承

不太确定如何表达这个问题,因为它是“为什么这行不通?”查询类型。我已将我的特定问题简化为以下代码:publicinterfaceIFoo{}publicclassFoo:IFoo{}publicclassBarwhereT:IFoo{publicBar(Tt){}publicBar():this(newFoo())//cannotconvertfrom'Foo'to'T'{}}现在,泛型类型T在Bar类必须实现IFoo。那么为什么编译器会给我注释中的错误呢?Foo的实例肯定是IFoo,因此可以作为通用类型的代表传递T?这是编译器限制还是我遗漏了什么? 最佳答

C# 泛型约束

这个问题在这里已经有了答案:Isthereaconstraintthatrestrictsmygenericmethodtonumerictypes?(24个答案)关闭8年前。是否可以枚举在泛型约束中“可用”的类型?TMyMethod()whereT:int,double,string我为什么要这样做是因为我有一个小型评估引擎,并且想像这样编写代码:boolexpression.Evaluate();或intexpression.Evaluate();但我想禁止MyCustomClassexpression.Evalaute();