Compartilhar via


Usando construtores (Guia de Programação em C#)

Quando uma classe ou struct é instanciada, seu construtor é chamado. Os construtores têm o mesmo nome que a classe ou struct e eles geralmente inicializam os membros de dados do novo objeto.

No exemplo a seguir, uma classe chamada Taxi é definida usando um construtor simples. A classe é então instanciada com o operador new. O construtor Taxi é invocado pelo operador new imediatamente depois que a memória é alocada para o novo objeto.

public class Taxi
{
    public bool IsInitialized;

    public Taxi()
    {
        IsInitialized = true;
    }
}

class TestTaxi
{
    static void Main()
    {
        Taxi t = new Taxi();
        Console.WriteLine(t.IsInitialized);
    }
}

Um construtor que não usa parâmetros é chamado construtor sem parâmetros. Construtores sem parâmetros são invocados sempre que um objeto é instanciado usando o operador new e nenhum argumento é fornecido para new. O C# 12 apresenta construtores primários. Um construtor primário especifica parâmetros que devem ser fornecidos para inicializar um novo objeto. Para obter mais informações, consulte Construtores de instâncias.

A menos que a classe seja estático, classes sem construtores recebem um construtor público sem parâmetros pelo compilador C# para habilitar a instanciação de classe. Para obter mais informações, consulte Classes estáticas e membros de classes estáticas.

Você pode impedir que uma classe seja instanciada tornando o construtor privado, da seguinte maneira:

class NLog
{
    // Private Constructor:
    private NLog() { }

    public static double e = Math.E;  //2.71828...
}

Para obter mais informações, consulte Construtores particulares.

Construtores para tipos struct se assemelham a construtores de classe. Quando um tipo de struct é instanciado com new, um construtor é invocado. Quando um struct é definido como seu valor default, o runtime inicializa toda a memória no struct como 0. Se declarar os inicializadores de campo em um tipo de struct, você deverá fornecer um construtor sem parâmetros. Para obter mais informações, consulte a seção Inicialização de struct e valores padrão do artigo Tipos de estrutura.

O código a seguir usa o construtor sem parâmetros para Int32, para que você tenha certeza de que o inteiro é inicializado:

int i = new int();
Console.WriteLine(i);

O código a seguir, no entanto, causa um erro do compilador porque ele não usa newe porque tenta usar um objeto que não foi inicializado:

int i;
Console.WriteLine(i);

Como alternativa, objetos baseados em structs (incluindo todos os tipos numéricos internos) podem ser inicializados ou atribuídos e, em seguida, usados como no exemplo a seguir:

int a = 44;  // Initialize the value type...
int b;
b = 33;      // Or assign it before using it.
Console.WriteLine("{0}, {1}", a, b);

As classes e os structs podem definir construtores que assumem parâmetros, incluindo construtores primários. Os construtores que usam parâmetros devem ser chamados por meio de uma instrução new ou uma instrução base. Classes e structs também podem definir vários construtores e nenhum deles é necessário para definir um construtor sem parâmetros. Por exemplo:

public class Employee
{
    public int Salary;

    public Employee() { }

    public Employee(int annualSalary)
    {
        Salary = annualSalary;
    }

    public Employee(int weeklySalary, int numberOfWeeks)
    {
        Salary = weeklySalary * numberOfWeeks;
    }
}

Essa classe pode ser criada usando uma das seguintes instruções:

Employee e1 = new Employee(30000);
Employee e2 = new Employee(500, 52);

Um construtor pode usar a palavra-chave base para chamar o construtor de uma classe base. Por exemplo:

public class Manager : Employee
{
    public Manager(int annualSalary)
        : base(annualSalary)
    {
        //Add further instructions here.
    }
}

Neste exemplo, o construtor da classe base é chamado antes que o bloco do construtor seja executado. A palavra-chave base pode ser usada com ou sem parâmetros. Todos os parâmetros para o construtor podem ser usados como parâmetros para baseou como parte de uma expressão. Para obter mais informações, consulte base.

Em uma classe derivada, se um construtor de classe base não for chamado explicitamente usando a palavra-chave base, o construtor sem parâmetros, se houver um, será chamado implicitamente. As seguintes declarações de construtor são efetivamente as mesmas:

public Manager(int initialData)
{
    //Add further instructions here.
}
public Manager(int initialData)
    : base()
{
    //Add further instructions here.
}

Se uma classe base não oferecer um construtor sem parâmetros, a classe derivada deverá fazer uma chamada explícita para um construtor base usando base.

Um construtor pode invocar outro construtor no mesmo objeto usando a palavra-chave this. Como base, this podem ser usados com ou sem parâmetros e quaisquer parâmetros no construtor estão disponíveis como parâmetros para thisou como parte de uma expressão. Por exemplo, o segundo construtor no exemplo anterior pode ser reescrito usando this:

public Employee(int weeklySalary, int numberOfWeeks)
    : this(weeklySalary * numberOfWeeks)
{
}

O uso da palavra-chave this no exemplo anterior faz com que esse construtor seja chamado:

public Employee(int annualSalary)
{
    Salary = annualSalary;
}

Os construtores podem ser marcados como public, private, protected, internal, protected internal ou private protected. Esses modificadores de acesso definem como os usuários da classe podem construir a classe. Para obter mais informações, consulte Modificadores de Acesso.

Um construtor pode ser declarado estático usando a palavra-chave static. Construtores estáticos são chamados automaticamente, imediatamente antes de qualquer campo estático ser acessado e usados para inicializar membros de classe estática. Para obter mais informações, consulte Construtores estáticos.

Especificação da linguagem C#

Para obter mais informações, veja Construtores de instância e Construtores estáticos na Especificação de Linguagem C#. A especificação de idioma é a fonte definitiva para a sintaxe e o uso de C#.

Consulte também