草庐IT

class-design

全部标签

c# - 不能同时指定约束类和 0​​x104567910 或 'class' 约束

我正在尝试解决mockingissue通过创建IDbSet的自定义模拟。自定义模拟:publicclassDbSetMock:IDbSet{/*hiddenallotherimplementedmethods/properties*/publicTDerivedEntityCreate()whereTDerivedEntity:class,Tenant{thrownewNotImplementedException();}}create方法给出了一个构建错误,我不知道如何解决:cannotspecifybothaconstraintclassandthe'class'or'struct

c# - Class B 继承自 ClassA 时,如何将 List<Class> 转换为 List<Class>?

我将json字符串反序列化为List现在我想把它转换到List在我把它从BindModel方法。我需要转换,因为这些方法期望得到List.为什么我在转换时出错?毕竟,ClassB继承自ClassA.我该怎么办?附言这个问题是从thispost扩展而来的.在线newDataContractJsonSerializer(typeof(List));而不是List该类型将在运行时构建。publicoverrideobjectBindModel(...){varserializer=newDataContractJsonSerializer(typeof(List));MemoryStream

c# - ASP.net MVC View 是 "class"吗?

...首先,我这样做只是出于好奇。这里没有实际应用,只是为了了解和修补......ASP.NETView具有类似Model的属性和ViewData甚至还有方法。您甚至可以使用@Using就像普通的class.cs文件一样。我知道它的类型是WebPageView我的主要问题是:是一门课吗?应该是因为它是一个类型,但是..我应该也能做到这一点(Razor引擎):@{publicclassPerson{//etc...}varp=newPerson();}@p.Name但是我不能..为什么?注意:目前是C#、ASP.net初学者。 最佳答案

c# - 在 C# 中,使用值类型与引用类型

我的问题是:我们什么时候应该使用值类型,什么时候应该使用引用类型?两者的优缺点是什么?如果到处都使用引用类型怎么办?有什么坏处吗?也请讨论每一个的优点和缺点。我也想明白这一点。 最佳答案 对于代表值的小型不可变类型,您应该使用值类型。Nevermakemutablestructs.对于其他一切,使用引用类型。 关于c#-在C#中,使用值类型与引用类型,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q

c# - 简易喷油器 : Factory classes that need to create classes with dependencies

我有一个工厂类,它创建了几个不同类型的类。工厂在容器中注册。鉴于它们也具有依赖性,在工厂内部创建类的推荐方法是什么。我显然想避免对容器的依赖,但如果我新建这些类,那么它们将不会使用容器。例如publicclassMyFactory{publicIMyWorkerCreateInstance(WorkerTypeworkerType){if(workerType==WorkerType.A)returnnewWorkerA(dependency1,dependency2);returnnewWorkerB(dependency1);}}所以问题是我从哪里获得这些依赖项。一种选择是使它们成

c# - C++/命令行界面 : How do I declare abstract (in C#) class and method in C++/CLI?

以下C#代码在C++/CLI中的等价物是什么?publicabstractclassSomeClass{publicabstractStringSomeMethod();} 最佳答案 只需稍微混合关键字即可获得正确的语法。abstract在C#中位于前面,但在C++/CLI中位于末尾。与override关键字相同,今天也被C++11兼容的编译器识别,它们期望它位于函数声明的末尾。就像传统C++中的=0标记函数抽象一样:publicrefclassSomeClassabstract{public:virtualString^SomeM

c# - 部分类(class)的目的是什么?

我读了aboutpartialclasses并且,例如,我理解在VisualStudio创建Windows窗体时使用它们的原因,但不排除whenworkingonlargeprojects,spreadingaclassoverseparatefilesenablesmultipleprogrammerstoworkonitatthesametime.后来我看了thisexample我注意到大多数类都被声明为部分类。为什么? 最佳答案 部分类很有用的一个很好的例子是当类由工具(如VS)自动生成并且您希望能够扩展该类的功能并且在工具需

c# - System.Design 去哪儿了?

我正在制作一个使用ScintillaNet的C#项目,它说:Thereferencedassembly"ScintillaNet"couldnotberesolvedbecauseithasadependencyon"System.Design,Version=4.0.0.0,Culture=neutral,PublicKeyToken=b03f5f7f11d50a3a"whichisnotinthecurrentlytargetedframework".NETFramework,Version=v4.0,Profile=Client".Pleaseremovereferencesto

c# - 编辑 Resources.resx 文件时,Resources.Designer.cs 无法更新,因为 TFS 未将其 checkout

我正在使用TFS源代码管理。当我向我的资源文件-Resources.resx添加一个新的资源key并点击保存时,TFScheckoutResources.resx但不checkoutResources.Designer.cs。这会导致对Resources.Designer.cs的更新失败并出现错误:Thecommandyouareattemptingcannotbecompletedbecausethefile'Resources.Designer.cs'thatmustbemodifiedcannotbechanged.Ifthefileisundersourcecontrol,yo

C#。结构方法代码保存在内存中的什么地方?

众所周知,.NET将值类型保存在内存中(大部分在堆栈中,但在某些情况下也可能在堆中等)...我的问题是-结构的代码在哪里?如果我在结构中说出16字节的数据字段和其中的大量计算方法-我假设16字节将被复制到堆栈中并且方法代码存储在其他地方并为所有实例共享结构。这些假设是否正确? 最佳答案 MSIL存储在程序集的代码部分中-Windows在首次加载程序集时将其映射到内存中。首次执行该方法时,JIT会将MSIL编译为x86/x64代码。一旦该方法被编译到内存中,它通常会留在那里并由所有线程共享。在某些情况下,多个AppDomain会导致M