static (Riferimenti per C#)static (C# Reference)

Usare il modificatore static per dichiarare un membro statico, che appartiene allo stesso tipo invece che a un oggetto specifico.Use the static modifier to declare a static member, which belongs to the type itself rather than to a specific object. Il modificatore static può essere usato con classi, campi, metodi, proprietà, operatori, eventi e costruttori, ma non con indicizzatori, finalizzatori o tipi diversi da classi.The static modifier can be used with classes, fields, methods, properties, operators, events, and constructors, but it cannot be used with indexers, finalizers, or types other than classes. Per altre informazioni, vedere Classi statiche e membri di classi statiche.For more information, see Static Classes and Static Class Members.

EsempioExample

La classe seguente viene dichiarata come static e contiene solo metodi static:The following class is declared as static and contains only static methods:

static class CompanyEmployee
{
    public static void DoSomething() { /*...*/ }
    public static void DoSomethingElse() { /*...*/  }
}

Una costante o una dichiarazione di tipo è implicitamente un membro statico.A constant or type declaration is implicitly a static member.

Non è possibile fare riferimento a un membro statico tramite un'istanza.A static member cannot be referenced through an instance. Al contrario, è possibile farvi riferimento tramite il nome del tipo.Instead, it is referenced through the type name. Si consideri ad esempio la classe seguente:For example, consider the following class:

public class MyBaseC
{
    public struct MyStruct
    {
        public static int x = 100;
    }
}

Per fare riferimento al membro statico x, usare il nome completo MyBaseC.MyStruct.x, a meno che il membro non è accessibile dallo stesso ambito:To refer to the static member x, use the fully qualified name, MyBaseC.MyStruct.x, unless the member is accessible from the same scope:

Console.WriteLine(MyBaseC.MyStruct.x);

Quando un'istanza di una classe contiene una copia separata di tutti i campi istanza della classe, è disponibile solo una copia di ogni campo statico.While an instance of a class contains a separate copy of all instance fields of the class, there is only one copy of each static field.

Non è possibile usare questo per fare riferimento a funzioni di accesso di proprietà o metodi statici.It is not possible to use this to reference static methods or property accessors.

Se la parola chiave static viene applicata a una classe, tutti i membri della classe devono essere statici.If the static keyword is applied to a class, all the members of the class must be static.

Le classi e le classi statiche possono disporre di costruttori statici.Classes and static classes may have static constructors. I costruttori statici vengono chiamati in un determinato momento tra l'avvio del programma e la creazione di un'istanza della classe.Static constructors are called at some point between when the program starts and the class is instantiated.

Nota

La parola chiave static ha un uso più limitato rispetto a C++.The static keyword has more limited uses than in C++. Per un confronto con la parola chiave di C++, vedere Classi di archiviazione (C++).To compare with the C++ keyword, see Storage classes (C++).

Per illustrare i membri statici, si consideri una classe che rappresenta un dipendente della società.To demonstrate static members, consider a class that represents a company employee. Si supponga che la classe contenga un metodo di conteggio dei dipendenti e un campo per memorizzare il numero dei dipendenti.Assume that the class contains a method to count employees and a field to store the number of employees. Il metodo e il campo non appartengono a nessun dipendente dell'istanza.Both the method and the field do not belong to any instance employee. Appartengono invece alla classe aziendale.Instead they belong to the company class. Pertanto, devono essere dichiarati come membri statici della classe.Therefore, they should be declared as static members of the class.

EsempioExample

Questo esempio legge il nome e l'ID di un nuovo dipendente, il contatore dipendente viene incrementato di uno e vengono visualizzate le informazioni per il nuovo dipendente e il nuovo numero di dipendenti.This example reads the name and ID of a new employee, increments the employee counter by one, and displays the information for the new employee and the new number of employees. Per semplicità, questo programma legge il numero corrente di dipendenti dalla tastiera.For simplicity, this program reads the current number of employees from the keyboard. In un'applicazione reale, queste informazioni devono essere lette da un file.In a real application, this information should be read from a file.

public class Employee4
{
    public string id;
    public string name;

    public Employee4()
    {
    }

    public Employee4(string name, string id)
    {
        this.name = name;
        this.id = id;
    }

    public static int employeeCounter;

    public static int AddEmployee()
    {
        return ++employeeCounter;
    }
}

class MainClass : Employee4
{
    static void Main()
    {
        Console.Write("Enter the employee's name: ");
        string name = Console.ReadLine();
        Console.Write("Enter the employee's ID: ");
        string id = Console.ReadLine();

        // Create and configure the employee object.
        Employee4 e = new Employee4(name, id);
        Console.Write("Enter the current number of employees: ");
        string n = Console.ReadLine();
        Employee4.employeeCounter = Int32.Parse(n);
        Employee4.AddEmployee();

        // Display the new information.
        Console.WriteLine($"Name: {e.name}");
        Console.WriteLine($"ID:   {e.id}");
        Console.WriteLine($"New Number of Employees: {Employee4.employeeCounter}");
    }
}
/*
Input:
Matthias Berndt
AF643G
15
 * 
Sample Output:
Enter the employee's name: Matthias Berndt
Enter the employee's ID: AF643G
Enter the current number of employees: 15
Name: Matthias Berndt
ID:   AF643G
New Number of Employees: 16
*/

EsempioExample

Questo esempio mostra che anche se è possibile inizializzare un campo statico con un altro campo statico non ancora dichiarato, i risultati non saranno definiti fino a quando non si assegna in modo esplicito un valore al campo statico.This example shows that although you can initialize a static field by using another static field not yet declared, the results will be undefined until you explicitly assign a value to the static field.

class Test
{
    static int x = y;
    static int y = 5;

    static void Main()
    {
        Console.WriteLine(Test.x);
        Console.WriteLine(Test.y);

        Test.x = 99;
        Console.WriteLine(Test.x);
    }
}
/*
Output:
    0
    5
    99
*/

Specifiche del linguaggio C#C# language specification

Per altre informazioni, vedere la specifica del linguaggio C#.For more information, see the C# Language Specification. La specifica del linguaggio costituisce il riferimento ufficiale principale per la sintassi e l'uso di C#.The language specification is the definitive source for C# syntax and usage.

Vedere ancheSee also