Tag: 程序集

自定义assembly属性

我想知道我是否可以定义自定义程序集属性。 现有属性按以下方式定义: [assembly: AssemblyTitle("MyApplication")] [assembly: AssemblyDescription("This application is a sample application.")] [assembly: AssemblyCopyright("Copyright © MyCompany 2009")] 有什么办法可以做到以下几点: [assembly: MyCustomAssemblyAttribute("Hello World! This is a custom attribute.")]

使用程序集中的Web应用程序版本号(ASP.NET / C#)

如何获取引用程序集中的调用Web应用程序的版本号? 我试过使用System.Reflection.Assembly.GetCallingAssembly()。GetName(),但它只是给我dynamic编译的程序集(返回版本号0.0.0.0)。 更新:在我的情况下,我需要一个解决scheme,不需要引用回到Web应用程序程序集中的类。 杰森的答案在下面(标记为接受)符合这个要求 – 很多其他人在这里提交没有。

为什么引用程序集中的DbParameterCollection抽象中有三个属性,否则是虚拟的?

我将项目从project.json移动到新样式的csproj格式,它包含从DbParameterCollection派生的类。 在我真正的项目中,我正在使用多目标,但为了这个问题的目的,我们只需要关心net45 。 编译器告诉我,我必须重写以前没有的三个属性: IsFixedSize IsReadOnly IsSynchronized 如果你遵循这些文档链接(这是用于.NET 4.5),你会看到所有的属性是虚拟的 – 而不是抽象的。 如果我只是通过调用csc构build代码,一切都很好……只有在使用.NET Core SDK时才会遇到问题。 以下是重现问题的示例代码: 项目文件: <Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <TargetFramework>net45</TargetFramework> </PropertyGroup> </Project> C#代码: using System; using System.Collections; using System.Data.Common; public class DummyParameterCollection : DbParameterCollection { public override int Count => 0; public override object SyncRoot => null; public override void Remove(object value) {} public override […]

为什么GCC调用libc的sqrt()而不使用它的结果呢?

使用GCC 6.3,下面的C ++代码: #include <cmath> #include <iostream> void norm(double r, double i) { double n = std::sqrt(r * r + i * i); std::cout << "norm = " << n; } 生成以下x86-64程序集: norm(double, double): mulsd %xmm1, %xmm1 subq $24, %rsp mulsd %xmm0, %xmm0 addsd %xmm1, %xmm0 pxor %xmm1, %xmm1 ucomisd %xmm0, %xmm1 sqrtsd %xmm0, %xmm2 […]

如何获得C#.Net大会的名字?

有没有像这样的东西: AppDomain.CurrentDomain.GetAssemblyByName("TheAssemblyName") 所以不是循环通过AppDomain.CurrentDomain.GetAssemblies() ,我们可以直接得到特定的程序集。

mscorlib.dll和System.dll

为什么MS最初决定维护这两个独立的核心库? 也许他们有一些可扩展性的问题,但现在我从来没有看到任何types的应用程序,不需要这两个。 有没有人有这方面的内幕消息? 这并不重要,但多年来我一直在想。 PS。 我知道在两个库中有什么,我知道不同之处 – 我是Reflector的粉丝:)只是想知道两者的分离有什么实际用途。

学习汇编语言是否值得?

学习ASM还是值得的吗? 我知道一点,但是我没有真正使用它,或者没有正确地学习它,因为我在汇编程序中学习的所有东西都可以在十分之一的时间用C或C ++等语言来完成。 那么,我真的应该学习和使用ASM吗? 它会对我有什么好的专业吗? 它会增加我的机智吗? 总之,它会让我成为一个更好的程序员吗? 注意:我正在谈论像FASM或NASM这样的低级汇编,而不是像HLA (高级汇编)那样的东西。

reflection速度有多慢

我最近创build了一个接口层来区分DataAccessProvider和业务逻辑层。 通过这种方法,我们可以通过更改Web / App.Config中的值来随时更改DataAccessProvider的select。 (如果需要,可以提供更多的细节)。 无论如何,要做到这一点,我们使用reflection来完成我们可以工作的DataProvider类。 /// <summary> /// The constructor will create a new provider with the use of reflection. /// If the assembly could not be loaded an AssemblyNotFoundException will be thrown. /// </summary> public DataAccessProviderFactory() { string providerName = ConfigurationManager.AppSettings["DataProvider"]; string providerFactoryName = ConfigurationManager.AppSettings["DataProviderFactory"]; try { activeProvider = Assembly.Load(providerName); activeDataProviderFactory = (IDataProviderFactory)activeProvider.CreateInstance(providerFactoryName); […]

在汇编代码中“int 0x80”是什么意思?

有人可以解释下面的汇编代码是做什么的? int 0x80

Gacutil.exe成功添加程序集,但程序集不能在资源pipe理器中查看。 为什么?

我正在从Visual Studio命令提示符2010中运行GacUtil.exe来向GAC注册dll(CatalogPromotion.dll)。 运行该实用程序后,它说Assembly Successfully added to the cache ,并运行gacutil /l CatalogPromotionDll显示GAC包含程序集,但是当我从Windows资源pipe理器导航到C:\ WINDOWS \程序集时看不到程序集。 为什么我不能从Windows资源pipe理器中的WINDOWS \ assembly中看到程序集,但是我可以使用gacutil.exe来查看它? 背景:下面是我在VS工具的命令提示符中input的内容: C:\ _ Dev Projects \ VS Projects \ bmccormack \ CatalogPromotion \ CatalogPromotionDll \ bin \ Debug> gacutil / i CatalogPromotionDll.dll Microsoft(R).NET全局程序集caching实用程序。 版本4.0.30319.1 版权所有(c)微软公司。 版权所有。 程序集成功添加到caching C:\ _ Dev Projects \ VS Projects \ bmccormack \ CatalogPromotion \ […]