file (C# 參考)
自 C# 11 開始,file
內容關鍵字為類型修飾詞。
file
修飾詞會將最上層類型的範圍與可見度限制為宣告的檔案。 通常會將 file
修飾詞套用至來源產生器所寫入的類型。 檔案本機類型為來源產生器提供方便的方式,以避免在產生的類型之間發生名稱衝突。 file
修飾詞會宣告檔案本機類型,如下列範例所示:
file class HiddenWidget
{
// implementation
}
在檔案本機類型中巢狀結構的任何類型,也只會在宣告該類型的檔案中顯示。 組件中的其他類型可能會使用與檔案本機類型相同的名稱。 因為檔案本機類型只會顯示在宣告該類型的檔案中,所以這些類型不會建立命名衝突。
檔案本機類型不得是任何比 file
範圍更可見之成員的傳回型別或參數型別。 檔案本機類型不得是具有大於 file
範圍可見度之類型的欄位成員。 然而,較可見的類型可能會隱含地實作檔案本機介面類型。 該類型也可以明確實作檔案本機介面,但明確實作只能在 file
範圍內使用。
範例
下列範例顯示使用檔案本機類型來提供工作者方法的公用類型。 此外,公用類型會隱含地實作檔案本機介面:
// In File1.cs:
file interface IWidget
{
int ProvideAnswer();
}
file class HiddenWidget
{
public int Work() => 42;
}
public class Widget : IWidget
{
public int ProvideAnswer()
{
var worker = new HiddenWidget();
return worker.Work();
}
}
在另一個來源檔案中,您可以宣告名稱與檔案本機類型相同的類型。 看不到檔案本機類型:
// In File2.cs:
// Doesn't conflict with HiddenWidget
// declared in File1.cs
public class HiddenWidget
{
public void RunTask()
{
// omitted
}
}
C# 語言規格
如需詳細資訊,請參閱 C# 語言規格中的宣告協助工具,以及 C# 11 - 檔案本機類型功能規格。
另請參閱
意見反應
https://aka.ms/ContentUserFeedback。
即將登場:在 2024 年,我們將逐步淘汰 GitHub 問題作為內容的意見反應機制,並將它取代為新的意見反應系統。 如需詳細資訊,請參閱:提交並檢視相關的意見反應