剖析 AssemblyInfo.cs - 了解常用的特性 Attribute

【博主】反骨仔    【原文】http://www.cnblogs.com/liqingwen/p/5944391.html

  之前,我们通过《C# 知识回顾 - 特性 Attribute》已经了解如何创建和使用特性 Attribute,这次,让我们一起来看看每次使用 VS 创建项目时所自带的文件 AssemblyInfo.cs。

目录

AssemblyInfo.cs

随机挑选一个 AssemblyInfo.cs 文件,展开图中的代码,看箭头↓

using System.Reflection;
using System.Runtime.InteropServices; // 有关程序集的常规信息通过下列特性集
// 控制。更改这些特性值可修改
// 与程序集关联的信息。
[assembly: AssemblyTitle("MusicStore")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("Microsoft")]
[assembly: AssemblyProduct("MusicStore")]
[assembly: AssemblyCopyright("Copyright © Microsoft 2016")]
[assembly: AssemblyTrademark("")]
[assembly: AssemblyCulture("")] // 将 ComVisible 设置为 false 会使此程序集中的类型
// 对 COM 组件不可见。如果需要
// 从 COM 访问此程序集中的某个类型,请针对该类型将 ComVisible 特性设置为 true。
[assembly: ComVisible(false)] // 如果此项目向 COM 公开,则下列 GUID 用于 typelib 的 ID
[assembly: Guid("a9ef3281-9049-4a52-a2f1-2061d442200e")] // 程序集的版本信息由下列四个值组成:
//
// 主版本
// 次版本
// 内部版本号
// 修订版本
//
// 可以指定所有值,也可以使用“修订号”和“内部版本号”的默认值,
// 方法是按如下所示使用 "*":
[assembly: AssemblyVersion("1.0.0.0")]
[assembly: AssemblyFileVersion("1.0.0.0")]

一、全局特性

  大多数特性适用于特定的语言元素(如类或方法),但是,有种特性它们适用于整个程序集或模块,称为全局特性。如:AssemblyVersionAttribute 特性可用于向程序集中嵌入版本信息。

  全局特性在源代码中出现在任何顶级 using 指令以及任何类型、模块或命名空间声明之前。全局特性可显示在多个源文件,但是,在单一编译传递必须编译文件。在 C# 项目中,它们在 AssemblyInfo.cs 文件中。

  程序集特性是提供有关程序集的信息的值。它们分成以下类别:

    ①程序集标识特性

    ②信息性特性

    ③程序集清单特性

    ④强名称特性

  

  1.程序集标识特性

  三个特性 (使用强名称,如果适用) 确定程序集的标识:名称、版本和区域性。当在代码中引用时,这些特性构成程序集的完整名称需要。使用特性,可以将程序集的版本、区域性和名称值,由编译器,在 “程序集信息”对话框 的 Visual Studio IDE 设置,在创建程序集后,根据包含程序集清单的文件。AssemblyFlagsAttribute 特性指定程序集的多个副本是否可以共存。

图 - “程序集信息”对话框

图 - “程序集信息”对话框中的名词和 AssemblyInfo.cs 文件的对应关系

  2.信息性特性

  您可以使用信息性特性为程序集提供其他的公司或产品信息。

  3.程序集清单特性

  可以使用程序集清单特性提供程序集清单中的信息。其中包括标题、说明、默认别名和配置。

  4.强名称特性(不深入)

  一般存在 Visual Studio 的早期版本,若要使用强名称的程序集执行以下程序集级别特性:

    ①AssemblyKeyFileAttribute

    ②AssemblyKeyNameAttribute

    ③AssemblyDelaySignAttribute

  虽然现在仍支持,但是,给程序集签名的首选方法是使用“签名页”。(这里不深入了解)

二、已过时的特性:Obsolete

   Obsolete 特性指示某个程序实体标记为建议不再使用的一个。 每次使用对实体标记为过时根据随后将生成警告或错误。
     /// <summary>
/// 旧类
/// </summary>
[Obsolete("请使用 " + nameof(NewClass))]
class OldClass
{
public void Method() { }
} /// <summary>
/// 新类
/// </summary>
class NewClass
{
[Obsolete("请使用 " + nameof(NewMethod), true)]
public void OldMethod() { } public void NewMethod() { }
}
     class Program
{
static void Main(string[] args)
{
var oldClass = new OldClass();  //警告 var newClass = new NewClass();
newClass.OldMethod();  //报错
}
}

  在此示例中应用 Obsolete 特性类 OldClass 和方法 NewClass.OldMethod。此构造函数的第一个参数为警告或错误的信息,由于特性构造函数的第二个参数被应用于 NewClass.OldMethod 设置为 true,此方法将导致编译器错误,而使用 OldClass 只将生成警告的类。

三、条件特性:Conditional

  Conditional 特性执行方法依赖于预处理标识符。Conditional 属性是 ConditionalAttribute 的别名,可应用于方法或属性类。

  在此示例中,Conditional 应用于方法以启用或禁用程序特定诊断信息示:

     class Debug
{
[Conditional("DEBUG")]
public static void Output(string msg)
{
Console.WriteLine(msg);
}
} class Program
{
static void Main(string[] args)
{
Debug.Output("This is Debug!");
Console.WriteLine("Done!"); Console.Read();
}
}

  Conditional 特性通常用于在 DEBUG 标识符启用跟踪,并记录的功能的调试版本,但不在发布版本中。

  

  将之前的代码简单改动下,使用 #if…#endif 包扎,结果和上图是一样的。

    class Debug
{
public static void Output(string msg)
{
Console.WriteLine(msg);
}
} class Program
{
static void Main(string[] args)
{
#if DEBUG
Debug.Output("This is Debug!");
#endif Console.WriteLine("Done!"); Console.Read();
}
}

  使用 Conditional 更加整洁,当然也可以将平常不太到用到或者容易出错的方法在 #if…#endif 内部块标明。

四、调用方信息特性

  使用调用方信息属性,可以获取关于调用方的信息传递给方法。可以获取源代码、行号在源代码和调用方的成员名称的文件路径。

  若要获取成员调用方信息,请使用适用于可选参数的属性。每个可选参数指定默认值。

     internal class Program
{
private static void Main(string[] args)
{
CallerMethod();
Console.Read();
} public static void CallerMethod()
{
TraceMessage("我是调用者");
} public static void TraceMessage(string msg,
[CallerMemberName] string name = "",
[CallerFilePath] string filePath = "",
[CallerLineNumber] int lineNumer = )
{
Trace.WriteLine($"{nameof(msg)}: {msg}");
Trace.WriteLine($"{nameof(name)}: {name}");
Trace.WriteLine($"{nameof(filePath)}: {filePath}");
Trace.WriteLine($"{nameof(lineNumer)}: {lineNumer}");
}
}

  每次调用 CallerMethod 方法时,调用方信息将替换为可选参数的变量。

  1.备注

  你必须为每个可选参数指定显式默认值。不能将调用方信息特性应用于未指定为可选的参数。

  调用方信息特性不会使参数成为可选参数。相反,它们会在忽略此参数时影响传入的默认值。

  在编译时,调用方信息值将作为文本传入中间语言 (IL)。与异常的 StackTrace 特性的结果不同,这些结果不受模糊处理的影响。

  你可显式提供可选参数来控制调用方信息或隐藏调用方信息。

传送门

  《C# 知识回顾 - 特性 Attribute

  《C# 知识回顾 - 序列化

  《C# 知识回顾 - 表达式树 Expression Trees


【参考】微软官方文档

[C#] 剖析 AssemblyInfo.cs - 了解常用的特性 Attribute的更多相关文章

  1. 修改AssemblyInfo.cs自动生成版本号

    一. 版本号自动生成方法 1.把 AssemblyInfo.cs文件中的[assembly:AssemblyVersion("1.0.0.0")]改成[assembly:Assem ...

  2. .Net魔法堂:AssemblyInfo.cs文件详解

    一.前言 .net工程的Properties文件夹下自动生成一个名为AssemblyInfo.cs的文件,一般情况下我们很少直接改动该文件.但我们实际上通过另一个形式操作该文件.那就是通过在鼠标右键点 ...

  3. AssemblyInfo.cs文件参数具体讲解

    在asp.net中有一个配置文件AssemblyInfo.cs主要用来设定生成的有关程序集的常规信息dll文件的一些参数,下面是默认的AssemblyInfo.cs文件的内容具体介绍 //是否符合公共 ...

  4. AssemblyInfo.cs文件的作用

    在asp.net中有一个配置文件AssemblyInfo.cs主要用来设定生成的有关程序集的常规信息dll文件的一些參数,以下是默认的AssemblyInfo.cs文件的内容详细介绍 //是否符合公共 ...

  5. [0] AssemblyInfo.cs文件介绍

    AssemblyInfo.cs文件:包含程序版本.信息.版权的属性文件 先介绍AssemblyInfo.cs文件中的程序集属性 内容: using System.Reflection;using Sy ...

  6. WinForm中AssemblyInfo.cs文件参数具体讲解

    在.NET中有一个配置文件AssemblyInfo.cs主要用来设定生成的有关程序集的常规信息dll文件的一些参数,下面是默认的AssemblyInfo.cs文件的内容具体介绍 //是否符合公共语言规 ...

  7. AssemblyInfo.cs文件详解

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq395537505/article/details/49661555 一.前言 .net工程的Pr ...

  8. C#——Visual Studio项目中的AssemblyInfo.cs文件包含的配置信息

    Visual Studio程序集项目中的AssemblyInfo.cs文件中的内容 using System.Reflection; using System.Runtime.CompilerServ ...

  9. c#程序中的AssemblyInfo.cs

    在asp.net中有一个配置文件AssemblyInfo.cs主要用来设定生成的有关程序集的常规信息dll文件的一些参数,下面是默认的AssemblyInfo.cs文件的内容具体介绍 //是否符合公共 ...

随机推荐

  1. EasyMesh - A Two-Dimensional Quality Mesh Generator

    EasyMesh - A Two-Dimensional Quality Mesh Generator eryar@163.com Abstract. EasyMesh is developed by ...

  2. 架构设计:远程调用服务架构设计及zookeeper技术详解(下篇)

    一.下篇开头的废话 终于开写下篇了,这也是我写远程调用框架的第三篇文章,前两篇都被博客园作为[编辑推荐]的文章,很兴奋哦,嘿嘿~~~~,本人是个很臭美的人,一定得要截图为证: 今天是2014年的第一天 ...

  3. 开始学nodejs——net模块

    net模块的组成部分 详见 http://nodejs.cn/api/net.html 下面整理出了整个net模块的知识结构,和各个事件.方法.属性的用法 net.Server类 net.Socket ...

  4. C#文件安全管理解析

    在实际的项目开发中,我们经常需要使用到文件的I/O操作,主要包含对文件的增改删查等操作,这些基本的操作我们都是很熟悉,但是较少的人去考虑文件的安全和操作的管理等方面,例如文件的访问权限管理,文件数据的 ...

  5. 编写高质量代码:改善Java程序的151个建议(第7章:泛型和反射___建议106~109)

    建议106:动态代理可以使代理模式更加灵活 Java的反射框架提供了动态代理(Dynamic Proxy)机制,允许在运行期对目标类生成代理,避免重复开发.我们知道一个静态代理是通过主题角色(Prox ...

  6. MATLAB中绘制质点轨迹动图并保存成GIF

    工作需要在MATLAB中绘制质点轨迹并保存成GIF以便展示. 绘制质点轨迹动图可用comet和comet3命令,使用例子如下: t = 0:.01:2*pi;x = cos(2*t).*(cos(t) ...

  7. css_02之盒模型、渐变

    1.框模型:盒模型,①对象实际宽度=左右外边距+左右边框+左右内边距 + width:②对象实际高度=上下外边距+上下边框+上下内边距 + height: 2.外边距:margin:取值:①top(上 ...

  8. 【干货分享】流程DEMO-请休假

    流程名: 请假申请  流程相关文件: 流程包.xml WebService业务服务.xml WebService.asmx WebService.cs  流程说明: 流程中集成了webservice服 ...

  9. 解决使用IE8打开ADFS 3.0登录页面

    系统上线前一天,发现客户竟然有XP系统和2003系统,这些系统都不能访问外网.测试时,客户端是IE8,打开我们系统ADFS的登录页面,一直在Loading,无法打开,也不报错.后来通过fiddler跟 ...

  10. Android Studio:Failed to resolve ***

    更换电脑后,也更新了所有的SDK的tool,仍然报错:Failed to resolve  各种jar包,出现这种问题主要是因为在Android studio中默认不允许在线更新,修改方法如下: