草庐IT

Generics

全部标签

c# - 如何将泛型类型传递给泛型方法?

为什么我不能调用SomeGenericMethod>?classNotGeneric{}classGeneric{}classProgram{staticvoidMain(string[]args){PrintType(typeof(NotGeneric));PrintType(typeof(Generic));PrintType();PrintType>();//compilergoescrazyhere}staticvoidPrintType(){Console.WriteLine(typeof(T));}staticvoidPrintType(Typet){Console.Wri

c# - 'Y' 中的实体参与 'FK_Y_X' 关系。找到 0 个相关的 'X'。预计 1 'X'

我在X和Y之间有一个1..*关系,其中X是父级。当我尝试删除记录Y时,我收到以下异常消息:Entitiesin'Y'participateinthe'FK_Y_X'relationship.0related'X'werefound.1'X'isexpected.我目前正在尝试通过以下方式以通用的、断开连接的方式删除记录:publicboolDelete(TEntityentity){if(entity==null){returnfalse;}try{varentry=_context.Entry(entity);entry.State=EntityState.Deleted;_cont

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# - 使用泛型的 xUnit 理论测试

在xUnit中,我可以有一个使用这种形式的泛型的Theory测试:[Theory][MemberData(SomeScenario)]publicvoidTestMethod(TmyType){Assert.Equal(typeof(double),typeof(T));}publicstaticIEnumerableSomeScenario(){yieldreturnnewobject[]{1.23D};}这将给我通用T参数作为double。是否可以使用MemberData为具有如下签名的测试指定泛型类型参数:[Theory][MemberData(SomeTypeScenario)

c# - 泛型方法可以处理引用和可空值类型吗?

我有一系列扩展方法来帮助对IDataRecord对象进行空值检查,我目前是这样实现的:publicstaticint?GetNullableInt32(thisIDataRecorddr,intordinal){int?nullInt=null;returndr.IsDBNull(ordinal)?nullInt:dr.GetInt32(ordinal);}publicstaticint?GetNullableInt32(thisIDataRecorddr,stringfieldname){intordinal=dr.GetOrdinal(fieldname);returndr.Get

C# 编译器无法识别正在实现接口(interface)的类

以下代码无法编译(使用VS2010),我不明白为什么。编译器应该能够推断出List与IEnumerable兼容(抱歉找不到更好的词),但不知何故它没有。我在这里缺少什么?interfaceITest{voidTest();}classTestClass:ITest{publicvoidTest(){}}classProgram{staticvoidTest(IEnumerabletests){foreach(vartintests){Console.WriteLine(t);}}staticvoidMain(string[]args){varlst=newList();Test(lst

c# - 接口(interface)作为参数或泛型方法与 where - 有什么区别?

有什么区别:publicvoidMethod1(class1c,Tobj)whereT:Imyinterface和publicvoidMethod2(class1c,Imyinterfaceobj)?使用第一种方法有什么好处? 最佳答案 如前所述,void方法在用法上没有太大区别。如果您查看幕后,您会发现使用泛型方法时,.NET将为您调用它的每种类型编译一个单独的方法。这具有在使用结构调用时避免装箱的效果。当您使用返回类型时,会出现很大的不同。publicTMethod1(class1c,Tobj)whereT:IMyInterfa

C#:使用泛型创建指针数组

大家下午好如果你愿意,可以提供一点帮助。为了规避.NET中的2Gb对象限制,我制作了一个在堆上分配内存的类,这允许我创建不超过可用RAM限制的数组。然而,为了便于开发(因为它是一个概念证明),它被硬编码了很长时间。现在它可以工作了,我一直在尝试更改代码以使用泛型,这样我就可以对多种类型使用相同的代码。在分配内存和正确索引数组时,我需要一个与数组将保存的类型相同的指针数组,即长数组需要long*[]myLargeArray。问题是当我使用泛型时,这个声明变成了T*[]myLargeArray,它总是产生错误'Cannottaketheaddressof,getthesizeof,orde

c# - C# 中的 C++ 样式模板,以任何方式可能吗?

我想为每个基本类型设置二维vector类。现在,为了确保最佳的运行时性能并能够使用许多实用函数,我需要为每个基元(Vector2Int、Vector2Float、Vector2Long等)创建一个单独的类。这只是大量的复制粘贴,如果我必须进行更改,我必须记住在每个类和每个实用程序函数中都进行更改。有没有什么可以让我编写类似C++模板的东西(或者有什么方法可以创建它)?我创建了一个小概念来向您展示它是如何工作的://compileisakeywordIjustinventedforcompile-timegenerics/templatesclassVector2compileT:int

c# - 从 DbContext 检索 DbSet<T> 的通用方法

我在大型数据库(由200多个表组成)中使用EntityFramework。尝试创建一个返回DbSet的通用方法特定表的T(即类,可以是TableA)。使用实体数据模型(自动)创建的实体类如下所示:publicpartialclasssqlEntities:DbContext{publicvirtualDbSetTableA{get;set;}publicvirtualDbSetTableB{get;set;}publicvirtualDbSetTableC{get;set;}...//othermethods}我的主类是这样的publicclassTableModifier{//Sho