您的位置:首页 > 编程语言 > ASP

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

2012-12-07 23:14 996 查看
[什么是动态链接库?]

动态链接库英文为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】


更多精彩博文请移步博客主页:http://blog.csdn.net/ls_man


更多精彩分享请收听博主腾讯微博@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> 此模块所属程序集的名称。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐