如何用CSC.exe来编译Visual C#的代码文件之四(转)

十五./nologo

   这个选项禁止在编译器启动时显示开始标志和编译过程中显示报告信息。

   例子:

csc /nologo my.cs

   十六./nooutput

   编译文件,但不创建任何输出文件。用户可以看到任何编译错误和警告。

   例子:

csc /nooutput my.cs

   十七./nostdlib

   这个选项禁止导入mscorlib.dll。这个DLL包含了这个系统名称空间。当用户希望使用自己的系统名称空间时,一般才会使用此选项。

   例子:编译文件,但不导入mscorlib.dl

csc /nooutput myOutput.cs

   十八./nowarn

   本选项是在编译过程中禁止指定的警告类型。如果是禁止多个警告类型,用逗号分隔。
例子:在编译过程中禁止警告类型CS0108和CS0109

csc /nowarn:108,109 Warn.cs

   十九./optimize

   本选项激活或者禁用由编译器执行优化。优化的结果是使得输出文件更小、更快、更有效率。缺省是/optimize执行优化,如果你选用了/optimize-则禁止优化。/o是/optimize的简写。

   例子:编译文件,并禁止优化

csc /optimise- my.cs

   二十./out

   在没有指定输出文件的情况下,如果通过编译器编译后文件是EXE文件,则输出文件将从包含Main方法的源代码的文件中获得名字;如果编译后的文件是DLL文件,将从第一个源代码文件中获得名字。如果用户想要指定输出文件名称,就可以使用此选项。

   例子:编译HelloWord.cs文件,并把输出文件命名为Hello.exe

csc /out:Hello.exe helloworld.cs

   二十一./recurse

   此选项允许用户编译在指定目录或者工程目录的所以子目录中的所有源代码文件。用户可以使用通配符来编译工程目录下的所有匹配文件。

   例子:编译/dir1/dir2目录下及其下级目录中的所有C#文件,并生成dir2.dll

csc /target:library /out:dir2.dll /recurse: dir1dir2*.cs

   二十二./refrence

   此选项可使得当前编译工程使用指定文件中的公共类型信息。这个选项对于初学者是很重要的。此选项的简写是/r。你必须引用在程序代码中使用"using"关键字导入的所有文件,如果在你的程序中,使用了自己编写的类库,在编译时也必须引用。

   例子:编译文件,并引用在程序中使用的文件

csc /r:system.dll;myExec.exe;myLibrary.dll myProject.cs

   (注:其中那个myExec.exe和myLibrary.dll时自己创建的)

   二十三./target

   这个选项是告诉编译器你所想得到什么类型的输出文件。除非使用/target:module选项,其他选项创建的输出文件都包含着汇编名单。汇编名单存储着编译中所有文件的信息。在一个命令行中如果生成多个输出文件,但只创建一个汇编名单,并存储在第一个输出文件中。

   下面是/target的4种用法:

   /target:exe 创建一个可执行(EXE)的控制台应用程序

   /target:library 创建一个代码库(DLL)

   /target:winexe 创建一个 windows程序(EXE)

   /target:module 创建一个模块(DLL)

   例子:

   csc /target:exe myProj.cs // 创建一个EXE文件

   csc /target:winexe myProject.cs file://创建一个 windows程序

   csc /target:library myProject.cs file://创建一个代码库

   csc /target:module myProject.cs file://创建一个模块

   二十四./resource

   此选项和/linkresource正好相反。他的作用是把.Net资源文件嵌入到输出文件中,参数、用法都和/linkresource也相同,具体可参考前面/linkresource选项。
   二十五./unsafe

   此选项是告诉编译器采用非安全模式编译文件

   例子:用非安全模式编译my.cs

csc /unsafe my.cs

   二十六./warn

   使用本选项是在编译过程中采用什么等级的警告级别

警告级别 含义
0 关闭所有警告
1 只显示严重警告
2 级别为1的警告和某些不严重的警告
3 级别为2的警告和某些不算非常严重的警告
4 级 别为3的警告和信息警告

   例子:编译文件,不显示任何错误

csc /warn:0 my.cs

   二十七./warnaserror

   告诉编译器把在编译中把所有的警告当成错误来处理。/warnaserror-是缺省选项,在该选项下编译中的警告不影响文件的输出。/warnaserror和/warnaserror+是一样的。

   例子:编译文件,并在编译中把警告当成错误

csc /warnaserror myj.cs

   二十八./win32icon

   在输出文件中插入一个图标文件(.ico)。从而在 Windows中的资源管理器中就看到以此图标标识的文件了。

   例子:

csc /win32icon:myicon.ico my.cs

   二十九./win32res

   在输出文件中添加一个win32的资源文件。此资源文件包括用户应用程序的版本信息或者位图(图标)信息。如果用户不指定/win32res,编译器将根据汇编版本生成版本信息。

   例子:添加一个win32资源文件到输出文件中

csc /win32res:winrf.res mt.cs

   以上就是Csc.exe在编译C#文件中的全部选项。了解并掌握这些选项有时对我们编程是大大有用的。
如何用CSC.exe来编译Visual C#的代码文件之三(转)
 九./define

   此选项在程序中定义了一个符号,他和在源程序中使用#define预处理程序指示功能相同,此符号保持已定义状态,直到源文件中的#undef指示符删除定义或者编译器已到达了文件末尾。你可以用/d简写来代替。

   例子:下面是my.cs的源程序

using System;
public class myBuild{
public static void Main() {
#if (final)
Console.WriteLine("Final Build");
#else
Console.WriteLine("Trial Build");
#endif
}
}

   如果用csc /define:final my.cs来编译就会显示"Final Build",如果没有/define,编译后执行就会显示"Trial Build"。

   十./doc

   文档在当今已经变得愈来愈重要了,一个好的程序应该配有相当的文档。如果你在写程序的文档中用的是"///"标识符来注释。当你使用/doc选项来编译时,你的所以注释文档将会自动的保留在一个XML文件中。

   例子:以下是my.cs 的源程序

using System ;
///
/// This is a sample class that has some documentation
///
public class myDocument {

///
/// Main entry point of the class
///
public static void Main (string[] argv)
{
Console.WriteLine("A Sample Class") ;
}
}

   用下列编译语句会产生my.xml文件,看看my.xml文件到底存储了什么东西。

Csc /doc:my.xml my.cs

   十一./fullpaths

   在默认情况下,编译产生的错误或者警告都只会指明发现错误的文件名称,加入此选项使得在编译器产生错误或者警告的时候会显示完整的路径。你可以把上面的my.cs程序语法搞错,再用 csc /fullpaths my.cs 和 csc my.cs分别编译,看看错误提示有什么不同。

   十二./incremental

   本选项主要是激活增量编译器,这种编译器只对上次编译后发生改变的函数进行编译。如果在编译时候选用了/debug选项,调试信息的状态存储在相应的.pdb文件中。除此编译时的信息都存储在.incr文件中,此.incr文件的名称为output_file_name.extension.incr。即如果输出文件时out.exe,则此文件对应的incr文件是out.exe.incr文件。

   例子:利用增量编译器来编译文件

csc /incremental /out:my.exe my.cs

   如果编译成功则会产生2个文件,分别是:my.exe和my.exe.incr。

   十三./linkresource

   这个选项就是在输出文件中创建到.Net资源的链接。他的简写是/linkres。资源文件就是在那些在工程文件中使用到的所有的资源,像图片、声音等。这个选项只是对于资源文件建立链接,这样有助于管理使用同一资源的程序,而不需要多个副本。此选项的具体语法如下:

/linkresource:filename,identifier,mimetype

   其中:

   filename:是想建立链接的.Net的资源文件

   identifier(可选):资源的逻辑名称,该名称用于载入资源,默认名称是文件名称。

   mimetype(可选):是一个代表资源的媒介类型的字符串。默认为空。

   例子:在文件中建立一个指向reso.resource的链接

csc /linkres:reso.resource myResource.cs


   十四./main

   当我们编译二个或者多个拥有Main方法的Class,我们可以使用这个选项让用户指定最终的输出文件中的使用那个Main的方法。

   例子:编译二个文件,但输出文件中的Main方法来自Main1 Class


你可能感兴趣的:(C#)