VS 命令行编译C#项目

命令行语法规则
当解释操作系统命令行上给出的参数时,C#   编译器代码使用下面的规则:  
参数用空白分隔,空白可以是一个空格或制表符。  
^   字符   (^)   未被识别为转义符或者分隔符。该字符在被传递给程序中的   argv   数组前,完全由操作系统的命令行分析器进行处理。  
无论其中有无空白,包含在双引号   ( "string ")   中的字符串均被解释为单个参数。带引号的字符串可以嵌入在参数内。  
前面有反斜杠的双引号   (\ ")   被解释为原义双引号字符   ( ")。  
反斜杠按其原义解释,除非它们紧位于双引号之前。  
如果偶数个反斜杠后跟双引号,则每对反斜杠中的一个反斜杠放置在   argv   数组中,并且双引号被解释为字符串分隔符。  
如果奇数个反斜杠后跟双引号,则每对反斜杠中的一个反斜杠放置在   argv   数组中,双引号由其余的反斜杠“转义”,使原义双引号   ( ")   被放置在   argv   数组中。  
命令行示例
编译   File.cs   以产生   File.exe:  
csc   File.cs  
编译   File.cs   以产生   File.dll:  
csc   /target:library   File.cs
编译   File.cs   并创建   My.exe:  
csc   /out:My.exe   File.cs
通过使用优化和定义   DEBUG   符号,编译当前目录中所有的   C#   文件。输出为   File2.exe:  
csc   /define:DEBUG   /optimize   /out:File2.exe   *.cs
编译当前目录中所有的   C#   文件,以产生   File2.dll   的调试版本。不显示任何徽标和警告:  
csc   /target:library   /out:File2.dll   /warn:0   /nologo   /debug   *.cs
将当前目录中所有的   C#   文件编译为   Something.xyz(一个   DLL):  
csc   /target:library   /out:Something.xyz   *.cs

 

示例:

打开Visual Studio 2008 命令提示,输入如下:

csc /t:library /r:System.dll,System.Web.Services.dll d:\WebSite1\Service.cs

生成的dll应该在下面这个目录里:

C:\Program Files\Microsoft Visual Studio 9.0\VC

posted @ 2011-12-02 02:31  冒牌工程师  阅读(2169)  评论(0编辑  收藏  举报