Asp.net_关于怎么利用编译器把[.cs]文件生成动态链接库[.dll]文件方法的总结

Asp.net_关于如何利用编译器把[.cs]文件生成动态链接库[.dll]文件方法的总结

[什么是动态链接库?]

动态链接库英文为DLL,是Dynamic Link Library 的缩写形式,DLL是一个包含可由多个程序同时使用的代码和数据的库,DLL不是可执行文件。动态链接提供了一种方法,使进程可以调用不属于其可执行代码的函数。函数的可执行代码位于一个 DLL 中,该 DLL 包含一个或多个已被编译、链接并与使用它们的进程分开存储的函数。DLL 还有助于共享数据和资源。多个应用程序可同时访问内存中单个DLL 副本的内容。DLL 是一个包含可由多个程序同时使用的代码和数据的库。

[动态链接库的优点]

1、扩展了应用程序的特性

2、简化了软件项目的管理

3、有助于节省内存

4、有助于资源共享

5、有助于应用程序的本地化

在安装了Microsoft.NET Framework的操作系统上,我们可以在Windows所在目录下找到Microsoft.NET目录。在这个目录下面提供了C#的编译器:CSC.EXE


【编辑】

新建类库ZZZ.cs

using XXX;
using YYY;
using System;

namespace ZZZ
{
    /// <summary>AAA</summary>
    /// <version>1.0 2012-12-07</version>
    /// <author>Tomy<see cref="http://t.qq.com/ls_man/">
    /// </see></author>
    public class AAA
    {
       public static void aaaMethod()
       {
       }
    }
}

示例说明:XXX、YYY命名空间分别是引用的动态链接库1.dll、2.dll,dll文件放置在Bin目录中,System命名空间是framework的动态链接库System.dll中定义的,此文件在C:\Windows\Microsoft.NET\Framework\v3.5目录中。

【生成】

以3.5版本为例,运行CMD,cd 命令定位到framework版本目录

cd C:\Windows\Microsoft.NET\Framework\v3.5

使用编译器编译
C:\Windows\Microsoft.NET\Framework\v3.5>csc /target:library /out:ZZZ.DL
L D:\PROJECT\App_Code\ZZZ.cs /r:E:\PROJECT\Bin\1.
dll,E:\PROJECT\App_Code\2.dll,System.dll /doc:ZZZ.XML
编译成功后提示以下内容,否则会有错误提示
适用于 Microsoft(R) .NET Framework 3.5 版的 Microsoft(R) Visual C# 2008 编译器 3
.5.30729.4926
 版
版权所有(C) Microsoft Corporation。保留所有权利。

说明:ZZZ.DLL为输出的文件名,D:\PROJECT\App_Code\ZZZ.cs为代码文件路径,/r:后面为引用到的其他动态链接库,多个引用以“.”分隔,ZZZ.XML为提示文档

生成成功后在C:\Windows\Microsoft.NET\Framework\v3.5目录下即可找到ZZZ.DLL文件。


【使用】

在Asp.net项目中把动态链接库[.dll](ZZZ.DLL)和提示文档ZZZ.XML文件放在Bin目录下,使用是引入ZZZ.cs中定义的命名空间ZZZ即可

using ZZZ;

namespace TestDll
{
   class test
   {
      AAA.aaaMethod();
   }
}

【扩展阅读】

MSDN:http://msdn.microsoft.com/zh-cn/library/78f4aasd.aspx

                http://msdn.microsoft.com/zh-cn/library/6s2x2bzy.aspx

【End】

Asp.net_关于怎么利用编译器把[.cs]文件生成动态链接库[.dll]文件方法的总结更多精彩博文请移步博客主页:http://blog.csdn.net/ls_man

Asp.net_关于怎么利用编译器把[.cs]文件生成动态链接库[.dll]文件方法的总结更多精彩分享请收听博主腾讯微博@ls_man:http://t.qq.com/ls_man


【附:CSC.EXE编译器详细参数】

- 输出文件 - 

/out:<file> 指定输出文件名(默认值: 包含主类的文件或第一个文件的基名称) 

/target:exe 生成控制台可执行文件(默认) (缩写: /t:exe) 

/target:winexe 生成 Windows 可执行文件 (缩写: /t:winexe) 

/target:library 生成库 (缩写: /t:library) 

/target:module 生成能添加到其他程序集的模块 (缩写: /t:module) 

/delaysign[+|-] 仅使用强名称密钥的公共部分对程序集进行延迟签名 

/doc:<file> 要生成的 XML 文档文件 

/keyfile:<file> 指定强名称密钥文件 

/keycontainer:<string> 指定强名称密钥容器 

/platform:<string> 限制可以在其上运行此代码的平台: x86、Itanium、x64 或 anycpu。默认值为 anycpu。  

- 输入文件 - 

/recurse:<wildcard> 根据通配符规范,包括当前目录和子目录下的所有文件 

/reference:<alias>=<file> 使用给定的别名从指定的程序集文件引用元数据 (缩写: /r) 

/reference:<file list> 从指定的程序集文件引用元数据 (缩写: /r) 

/addmodule:<file list> 将指定的模块链接到此程序集中  

- 资源 - 

/win32res:<file> 指定 Win32 资源文件(.res) 

/win32icon:<file> 使用该图标输出 

/resource:<resinfo> 嵌入指定的资源 (缩写: /res) 

/linkresource:<resinfo> 将指定的资源链接到此程序集 (缩写: /linkres) 其中 resinfo 的格式是 <file>[,<string name>[,public|private]]  

- 代码生成 - 

/debug[+|-] 发出调试信息 

/debug:{full|pdbonly} 指定调试类型(“full”是默认类型,可以将调试程序附加到正在运行的程序) 

/optimize[+|-] 启用优化 (缩写: /o)  

- 错误和警告 - 

/warnaserror[+|-] 将所有警告报告为错误 

/warnaserror[+|-]:<warn list> 将特定警告报告为错误 

/warn:<n> 设置警告等级(0-4) (缩写: /w) 

/nowarn:<warn list> 禁用特定的警告消息  - 语言 - 

/checked[+|-] 生成溢出检查 /unsafe[+|-] 允许“不安全”代码 

/define:<symbol list> 定义条件编译符号 (缩写: /d) 

/langversion:<string> 指定语言版本模式: ISO-1 或 Default  

- 杂项 - 

@<file> 有关更多选项,请阅读响应文件 

/help 显示此用法信息 (缩写: /?) 

/nologo 取消编译器版权信息 

/noconfig 不要自动包含 CSC.RSP 文件  

- 高级 - 

/baseaddress:<address> 要生成的库的基址 

/bugreport:<file> 创建“Bug 报告”文件。 

/codepage:<n> 指定打开源文件时要使用的代码页 

/utf8output 以 UTF-8 编码格式输出编译器消息 

/main:<type> 指定包含入口点的类型(忽略所有其他可能的入口点) (缩写: /m) 

/fullpaths 编译器生成完全限定路径 

/filealign:<n> 指定用于输出文件节的对齐方式 

/pdb:<file> 指定调试信息文件名(默认值: 扩展名为 .pdb 的输出文件名) 

/nostdlib[+|-] 不引用标准库(mscorlib.dll) 

/lib:<file list> 指定要在其中搜索引用的附加目录 

/errorreport:<string> 指定如何处理内部编译器错误: prompt、send、queue 或 none。默认值为 queue。 

/moduleassemblyname:<string> 此模块所属程序集的名称。