1、.Net工程的Properties文件夾下自動生成一個名為AssemblyInfo.cs的文件,一般情況下我們很少直接改動該文件。但我們實際上通過另一個形式操作該文件。那就是通過在滑鼠右鍵點擊項目的屬性進入“應用程式”->“程式集信息”,然後修改信息。 2、通過特性(Attribute)來設置程 ...
1、.Net工程的Properties文件夾下自動生成一個名為AssemblyInfo.cs的文件,一般情況下我們很少直接改動該文件。但我們實際上通過另一個形式操作該文件。那就是通過在滑鼠右鍵點擊項目的屬性進入“應用程式”->“程式集信息”,然後修改信息。
2、通過特性(Attribute)來設置程式集(dll文件)的常規信息,供查看或作為配置信息供程式內部使用。
此文件內容如下:
1 // 程式集標題
2 [assembly:AssemblyTitle("程式集標題")]
3 // 程式集描述
4 [assembly:AssemblyDescription("程式集描述")]
5 // 產品名稱
6 [assembly:AssemblyProduct("產品名稱")]
7 // 公司
8 [assembly:AssemblyCompany("公司名稱")]
9 // 合法商標
10 [assembly:AssemblyTrademark("合法商標")]
11 // 指定程式集支持的區域性
12 [assembly:AssemblyCulture("區域性")]
13 // 版權
14 [assembly:AssemblyCopyright("Copyright 2014")]
15 // 配置文件,如零售、發佈、調試等信息。程式集在運行時不會使用該信息
16 [assembly:AssemblyConfiguration("")]
17 // 程式集的版本信息由下麵四個值組成:
18 //
19 // 主版本
20 // 次版本
21 // 內部版本號
22 // 修訂號
23 //
24 // 可以指定所有這些值,也可以使用“內部版本號”和“修訂號”的預設值,
25 // 方法是按如下所示使用“*”:
26 [assembly:AssemblyVersion("1.0.0.0")]
27
28 // 控製程序集中所有類型對COM的可訪問性
29 [assembly:ComVisible(false)]
30 // 如果此項目向 COM 公開,則下列 GUID 用於類型庫的 ID
31 [assembly: Guid("77bf07c6-941f-4ba7-b95d-6a5c18401f74")]
3、 對生成的dll文件右鍵點擊屬性,即可查看到上述信息。
assembly: 表示特性以程式集作為作用範圍。
4、讀取Assembly特性
以讀取 [assembly:AssemblyProduct("")] 為例子
Type t = typeof(Program);
AssemblyProductAttribute productAttr = t.Assembly.GetCustomAttributes(typeof(AssemblyProductAttribute), true)[0] as AssemblyProductAttribute;
Console.WriteLine(productAttr.Product);
5、註意要點
1) [assembly:AssemblyProduct("")] 特性不限於在AssemblyInfo.cs文件中使用,而是可以在任何的.cs文件中使用。
2) 對於同一個特性,程式集中僅能設置一次,否則編譯時將報錯。
示例:
[assembly:AssemblyProduct("")]
namespace{
public class Demo{
}
}
轉載鏈接:https://www.cnblogs.com/fsjohnhuang/p/3992258.html