使用 csc.exe 建置命令列
您可以輸入名稱叫用 C# 編譯器可執行檔 (csc.exe) 在命令提示字元。
如果您使用 [Visual Studio 命令提示字元] 視窗,所有必要的環境變數會自動設定。 在 Windows 7 中,您可以從 [啟動] 功能表存取這個視窗來開啟 Microsoft Visual Studio 版本\ Visual Studio 工具資料夾。 在 Windows 8 中, Visual Studio 命令提示字元呼叫 [VS2012 的開發人員命令提示字元],然後,您可以從開始搜尋螢幕找到它。
如果您使用標準命令提示字元視窗,您必須調整路徑,才能叫用 csc.exe 從在電腦上的所有子目錄。 您也必須執行 vsvars32.bat 設定適當的環境變數支援命令列組建。 如需 vsvars32.bat 的詳細資訊,包括如何能找到並執行它,請參閱 HOW TO:設定環境變數。
如果您在具有僅適用於 Windows Software Development Kit (SDK)的電腦上,您可以使用 C# 編譯器在 [SDK 命令提示字元] 中,您可以從 [Microsoft .NET Framework SDK.] 功能表選項開啟。
您也可以使用 MSBuild 建置 C# 程式方式。 如需詳細資訊,請參閱MSBuild。
csc.exe 可執行檔通常位於 Microsoft.NET \ Framework \版本 資料夾在 Windows 目錄下。 它的位置可能會根據特定電腦的實際組態變更。 如果多個 .NET Framework 版本安裝在電腦上,您會看到這個檔案的多個版本。 如需這類安裝的詳細資訊,請參閱判斷安裝的 .NET Framework 版本。
提示
使用 Visual Studio IDE 中,當您建立專案,您可以顯示 [csc] 命令及其關聯的編譯器選項在 [輸出] 視窗中。若要顯示這項資訊,請依照 HOW TO:檢閱、儲存和設定建置記錄檔 中的指示變更詳細等級記錄資料到 [一般] 或 [詳細]。在您重新建置專案之後,請搜尋 [輸出] 視窗的 [csc] 尋找 C# 編譯器的引動過程。
本主題內容
命令列語法規則
命令列範例
C# 編譯器和 C++ 編譯器輸出的不同之處
C# 編譯器的命令列語法規則
C# 編譯器會使用下列規則,解譯在作業系統命令列上指定的引數:
引數會以空白或定位鍵的泛空白字元 (White Space) 進行分隔。
插入號字元 (^) 不會辨識為逸出字元 (Escape Character) 或分隔符號。 這個字元先由作業系統中的命令列剖析器 (Parser) 處理,再傳遞給程式中的 argv 陣列。
用雙引號括住的字串 ("string") 會解譯成單一引數,不論其內是否包含泛空白字元 (White Space)。 有引號的字串可以內嵌到引數中。
前面有反斜線的雙引號 (\") 會解譯為常值雙引號字元 (")。
反斜線會逐字解譯,除非後面緊接著雙引號。
如果偶數數目的反斜線後面接著雙引號,在 argv 陣列中會用一條反斜線代表一對反斜線,雙引號則會轉譯為字串分隔符號。
如果奇數數目的反斜線後面接著雙引號,在 argv 陣列中會用一條反斜線代表一對反斜線,雙引號則會使用剩下的反斜線「逸出」。 這樣會在 argv 中加入常值雙引號 (")。
C# 編譯器的簡單命令列
編譯 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
C# 編譯器和 C++ 編譯器輸出的不同之處
因為不會叫用 C# 編譯器所建立的目的檔 (.obj);輸出檔直接建立。 因此,C# 編譯器並不需要連結器 (Linker)。
請參閱
工作
HOW TO:使用 foreach 存取命令列引數 (C# 程式設計手冊)