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 - 檔案本機類型功能規格。

另請參閱