共用方式為


設定目標和工作

當開發電腦支援目標環境時,選取的 MSBuild 工作可以設定為在目標環境中執行。 例如,當您使用 64 位元 Windows 電腦來建置以 32 位元 Windows 架構為目標的應用程式時,就會在 32 位元處理程序中執行選取的工作。

注意

如果是以 .NET 語言 (例如 Visual C# 或 Visual Basic) 來撰寫組建工作,而未使用原生資源或工具,則它不需任何修改,即可在任何目標內容中執行。

UsingTask 屬性和工作參數

下列 UsingTask 屬性會影響特定建置程序中工作的所有作業:

  • Runtime 屬性如果存在的話,會設定通用語言執行平台 (CLR) 版本,並且可接受下列任何一個值:CLR2CLR4CurrentRuntime* (任何執行階段)。

  • Architecture 屬性如果存在的話,會設定平台和位元,並且可接受下列任何一個值:x86x64CurrentArchitecture* (任何架構)。

  • TaskFactory 屬性如果存在的話,會設定建立及執行工作執行個體的工作 Factory,並且只接受 TaskHostFactory 值。 如需詳細資訊,請參閱本文件中稍後的工作 Factory

<UsingTask TaskName="SimpleTask"
    Runtime="CLR2"
    Architecture="x86"
    AssemblyFile="$(MSBuildToolsPath)\Microsoft.Build.Tasks.v3.5.dll" />

您也可以使用 MSBuildRuntimeMSBuildArchitecture 參數來設定個別工作引動過程的目標內容。

<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
    <Target Name="MyTarget">
        <SimpleTask MSBuildRuntime="CLR2" MSBuildArchitecture= "x86"/>
    </Target>
</Project>

在 MSBuild 執行工作之前,它會尋找具有相同目標內容的相符 UsingTask。 在 UsingTask 中指定但未在對應的工作中指定的參數會視為相符。 在工作中指定但未在對應的 UsingTask 中指定的參數也會視為相符。 如果未在 UsingTask 或工作中指定參數值,值就會預設為 * (任何參數)。

警告

如果有多個 UsingTask 存在且全部都有相符的 TaskNameRuntimeArchitecture 屬性,則第一個要評估的項目會取代其他項目。 這與 PropertyTarget 元素的行為不同。

如果在工作上設定了參數,MSBuild 就會嘗試尋找與這些參數相符或至少不與它們衝突的 UsingTask。 可以有多個 UsingTask 來指定相同工作的目標內容。 例如,針對不同目標環境具有不同可執行檔的工作可能會像這樣:

<UsingTask TaskName="MyTool"
    Runtime="CLR2"
    Architecture="x86"
    AssemblyFile="$(MyToolsPath)\MyTool.v2.0.dll" />

<UsingTask TaskName="MyTool"
    Runtime="CLR4"
    Architecture="x86"
    AssemblyFile="$(MyToolsPath)\MyTool.4.0.dll" />

<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
    <Target Name="MyTarget">
        <MyTool MSBuildRuntime="CLR2" MSBuildArchitecture= "x86"/>
    </Target>
</Project>

覆寫預設 UsingTasks

根據預設,MSBuild 會將 UsingTask 的處理為「第一個獲勝」。從 17.2 開始,MSBuild 支援透過 Override 參數覆寫此行為。 將參數 Override 設為 true 的 UsingTask 會優先於相同 TaskName 的任何其他 UsingTask。

<UsingTask TaskName="MyTool"
    Runtime="CLR4"
    Architecture="x86"
    Override="true"
    AssemblyFile="$(MyToolsPath)\MyTool.4.0.dll" />

警告

這在每個工作只能進行一次。 嘗試為相同工作新增多個覆寫的組建會收到 MSBuild 錯誤 MSB4275

工作 Factory

下表顯示 MSBuild 安裝提供的工作 Factory:

工作 Factory 描述
AssemblyTaskFactory 這是預設值。 同處理序執行工作。
TaskHostFactory 執行流程外的工作。
RoslynCodeTaskFactory 針對以 C# 或 Visual Basic 撰寫且以 .NET Standard 為目標的內嵌工作;可與 msbuild.exedotnet build 搭配使用。
CodeTaskFactory 針對以 C# 或 Visual Basic 撰寫且以 .NET Framework 為目標的內嵌工作;只能與 msbuild.exe 搭配使用。

工作 Factory 機制可延伸,因此您也可以使用第三方建立的機制,或建立自己的機制。 建立內嵌工作是為了支援另一種撰寫內嵌工作的語言。

TaskHostFactory

MSBuild 會在執行工作之前,先檢查看看它是否是指定為在目前的軟體內容中執行。 如果是這樣指定工作的,MSBuild 就會將它傳遞給 AssemblyTaskFactory 以在目前的處理程序中執行它;否則,MSBuild 會將工作傳遞給 TaskHostFactory 以在符合目標內容的處理程序中執行它。 即使目前的內容和目標內容相符,您仍可藉由將 TaskFactory 設定為 TaskHostFactory,來強制讓工作跨處理序執行 (基於隔離、安全性或其他原因)。

<UsingTask TaskName="MisbehavingTask"
    TaskFactory="TaskHostFactory"
    AssemblyFile="$(MSBuildToolsPath)\MyTasks.dll">
</UsingTask>

明確指定 TaskHostFactory 時,執行工作的流程會短暫執行。 這可讓作業系統在執行工作之後立即清除與工作相關的所有資源。 基於這個理由,請在參考建置流程內建的工作時指定 TaskHostFactory ,以避免在建置後更新工作元件時發生檔案使用錯誤。

RoslynCodeTaskFactory

RoslynCodeTaskFactory 提供的機制,可讓您為專案檔中的工作撰寫 C# 或 Visual Basic 程式碼立即使用。 程式碼會在建置流程編譯,產生可在同一個組建執行的工作。 您撰寫的程式碼以 .NET Standard 為目標,因此執行 dotnet build 時可以使用,它使用 MSBuild (以及 .NET 5 和更新版本) 版本的 .NET Core,以及使用 .NET Framework 的 msbuild.exeRoslynCodeTaskFactory 最適合用於在 MSBuild 邏輯難以執行,但複雜度不足以建立個別專案的自訂。 請參閱使用 RoslynCodeTaskFactory 建立 MSBuild 內嵌工作

CodeTaskFactory

CodeTaskFactory 是舊版 RoslynCodeTaskFactory,僅限於 MSBuild 的 .NET Framework 版本。 請參閱 MSBuild 內嵌工作。 雖然支援此工作 Factory,但較新的程式碼應使用 RoslynCodeTaskFactory,適用性更廣泛。

虛設項目工作參數

MSBuildRuntimeMSBuildArchitecture 與任何其他工作參數相同,都可從建置屬性來設定。

<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
    <PropertyGroup>
        <FrameworkVersion>3.0</FrameworkVersion>
    </PropertyGroup>
    <Target Name="MyTarget">
        <SimpleTask MSBuildRuntime="$(FrameworkVerion)" MSBuildArchitecture= "x86"/>
    </Target>
</Project>

不同於其他工作參數,MSBuildRuntimeMSBuildArchitecture 對於工作本身並不明顯。 若要撰寫知道執行所在內容的工作,您必須藉由呼叫 .NET Framework 來測試內容,或使用建置屬性以透過其他工作參數傳遞內容資訊。

注意

UsingTask 屬性可以從工具組和環境屬性設定。

MSBuildRuntimeMSBuildArchitecture 參數提供最具彈性的方式,來設定目標內容,但是範圍也最受限制。 一方面,因為它們是設定在工作執行個體本身,並且在即將執行工作之前才會評估,所以它們可以從評估時間和建置階段可用屬性的完整範圍衍生其值。 在另一方面,這些參數僅適用於特定目標中工作的特定執行個體。

注意

工作參數是在父節點的內容中評估,不是工作主機的內容。 執行階段或架構相依的環境變數 (例如「程式檔案」位置) 將評估為符合父節點的值。 不過,如果工作直接讀取相同的環境變數,它會正確地在工作主機的內容中進行評估。