这开始是为了找到C++/CLI和托管C++程序集,以便可以测试它们内部的所有类以确保所有继承的方法都被重新实现。我想将此添加为构建流程步骤,以确保它不再发生。是否有可能确定.NET程序集事后写入哪种语言?
关于这个问题的思考也让我有点好奇,因为能够确定使用的任何.NET语言会很有趣。正因为如此,我进一步了解了所有.NET语言的程序集。到目前为止,这里是我通过一个小程序,我写了比较类型和通过反射属性从任何一组.NET程序集的数据发现:
- C# - 有AssemblyConfigurationAttribute,拥有GuidAttribute
- VB - 有许多额外的“我的”类型(例如MyApplication,MySettings),有GuidAttibute
- F# - 有一个FSharpInterfaceDataVersionAttribute,它也指定了所用编译器的版本。
- C++(all but/clr:safe) - 有一堆额外的类型(FrameInfo,type_info)
- C++/clr:safe - 似乎没有独特的反射功能。
它可能是合理的顺序来解析:
- 这是F#它是否具有FSharpInterfaceDataVersionAttribute
- 这是C++,如果有任何的庞大集合额外的类型,我发现的。
- 这是VB如果它有“我的*”类型。
- 这是C#如果它有AssemblyConfigurationAttribute或GuidAttribute
- 这很可能是C++/CLR:安全
然而,由于这是一个可怕的黑客,我想在这里检查,以确保有WASN另一个选项可用。
有趣的问题,但为什么使用拉丁?回顾性会更容易理解。并不是每个人都是以英语为母语的人。 – danio 2009-02-25 09:16:19