CSC.exe路径:C:\Windows\Microsoft.NET\Framework64\v4.0.30319\csc.exe
可以使用CSC.exe/?来察看可选项.
此编译器作为 Microsoft (R) .NET Framework 的一部分提供,但仅支持最高 C# 5 的语言版本,它不再是最新版本。 对于支持较新版本的 C# 编程语言的编译器,请参阅http://go.microsoft.com/fwlink/?LinkID=533240
输出文件
用于控制所生成的程序集的格式、可选的 XML 文档文件和强名称信息的选项。
/out:<文件> | 指定输出文件名(默认值: 包含主类的文件或第一个文件的基名称) |
---|---|
/target:exe | 生成控制台可执行文件(默认) (缩写: /t:exe) |
/target:winexe | 生成 Windows 可执行文件 (缩写: /t:winexe) |
/target:library | 生成库 (缩写: /t:library) |
/target:module | 生成能添加到其他程序集的模块 (缩写: /t:module) |
/target:appcontainerexe | 生成 Appcontainer 可执行文件 (缩写: /t:appcontainerexe) |
/target:winmdobj | 生成 WinMDExp 使用的 Windows 运行时中间文件 (缩写: /t:winmdobj) |
/doc:<文件> | 要生成的 XML 文档文件 |
/platform:<字符串> | 限制可以在其上运行此代码的平台: x86、Itanium、x64、arm、anycpu32bitpreferred 或anycpu。默认值为 anycpu。 |
输入文件
使用户可以指定输入文件和引用的程序集的选项。
/recurse:<通配符> | 根据通配符规范,包括当前目录和子目录下的所有文件 |
---|---|
/reference:<别名>=<文件> | 使用给定的别名从指定的程序集文件引用元数据 (缩写: /r) |
/reference:<文件列表> | 从指定的程序集文件引用元数据 (缩写: /r) |
/addmodule:<文件列表> | 将指定的模块链接到此程序集中 |
/link:<文件列表> | 嵌入指定的互操作程序集文件中的元数据 (缩写: /l) |
资源
用于将任何必需的资源(例如,图标和字符串表)嵌入到程序集中的选项。
/win32res:<文件> | 指定 Win32 资源文件(.res) |
---|---|
/win32icon:<文件> | 对输出使用此图标 |
/win32manifest:<文件> | 指定 Win32 清单文件(.xml) |
/nowin32manifest | 不包括默认 Win32 清单 |
/resource:<资源信息> | 嵌入指定的资源 (缩写: /res) |
/linkresource:<资源信息> | 将指定的资源链接到此程序集 (缩写: /linkres) 其中 resinfo 的格式是 |
代码生成
这些选项控制调试符号的生成。
/debug[+|-] | 发出调试信息,指定+,则创建调试版本,指定-,则创建正式版本 |
---|---|
/debug:{full|pdbonly} | 指定调试类型(“full”是默认类型,可以将调试程序附加到正在运行的程序) |
/optimize[+|-] | 启用优化 (缩写: /o)指定+,则开启编译器优化,指定-,则关闭编译器优化 |
错误和警告
控制编译器处理源代码错误/警告的方式。
/warnaserror[+|-] | 将所有警告报告为错误 |
---|---|
/warnaserror[+|-]:<警告列表> | 将特定警告报告为错误 |
/warn: |
设置警告等级(0-4) (缩写: /w) |
/nowarn:<警告列表> | 禁用特定的警告消息 |
语言
启用/禁用 C# 语言功能(例如,不安全代码)以及条件编译符号的定义。
/checked[+|-] | 生成溢出检查 |
---|---|
/unsafe[+|-] | 允许“不安全”代码 |
/define:<符号列表> | 定义条件编译符号 (缩写: /d) |
/langversion:<字符串> | 指定语言版本模式: ISO-1、ISO-2、3、4、5 或 Default |
安全性
可控制编译器安全选项。
/delaysign[+|-] | 仅使用强名称密钥的公共部分对程序集进行延迟签名 |
---|---|
/keyfile:<文件> | 指定强名称密钥文件 |
/keycontainer:<字符串> | 指定强名称密钥容器 |
/highentropyva[+|-] | 启用高平均信息量的 ASLR |
/enforcecodeintegrity[+|-] | 对编译器的所有输入强制执行代码完整性检查并启用加载已编译 如果操作系统是由其他程序强制执行代码完整性的程序集 配置为这样做。 |
杂项 -
该类别的最有趣的选项使您可以指定 csc.exe 响应文件。
@<文件> | 有关更多选项,请阅读响应文件 |
---|---|
/help | 显示此用法信息 (缩写: /?) |
/nologo | 取消编译器版权信息 |
/noconfig | 不要自动包含 CSC.RSP 文件 |
高级
该类别指定一些更加深奥并且通常不太重要的编译器选项。
/baseaddress:<地址> | 要生成的库的基址 |
---|---|
/bugreport:<文件> | 创建“Bug 报告”文件 |
/codepage: |
指定打开源文件时要使用的代码页 |
/utf8output | 以 UTF-8 编码格式输出编译器消息 |
/main:<类型> | 指定包含入口点的类型(忽略所有其他可能的入口点) (缩写: /m) |
/fullpaths | 编译器生成完全限定路径 |
/filealign: |
指定用于输出文件节的对齐方式 |
/pdb:<文件> | 指定调试信息文件名(默认值: 扩展名为 .pdb 的输出文件名) |
/errorendlocation | 输出每个错误的结束位置的行和列 |
/preferreduilang | 指定首选输出语言名称。 |
/nostdlib[+|-] | 不引用标准库(mscorlib.dll) |
/subsystemversion:<字符串> | 指定此程序集的子系统版本 |
/lib:<文件列表> | 指定要在其中搜索引用的附加目录 |
/errorreport:<字符串> | 指定如何处理内部编译器错误: prompt、send、queue 或 none。默认值为 queue。 |
/appconfig:<文件> | 指定一个包含程序集绑定设置的应用程序配置文件 |
/moduleassemblyname:<字符串> | 此模块所属程序集的名称 |