override (referenční dokumentace jazyka C#)
override
Modifikátor je nutný k rozšíření nebo úpravě abstraktní nebo virtuální implementace zděděné metody, vlastnosti, indexeru nebo události.
V následujícím příkladu Square
musí třída poskytnout přepsánou implementaci, protože GetArea
GetArea
je zděděna z abstraktní Shape
třídy:
abstract class Shape
{
public abstract int GetArea();
}
class Square : Shape
{
private int _side;
public Square(int n) => _side = n;
// GetArea method is required to avoid a compile-time error.
public override int GetArea() => _side * _side;
static void Main()
{
var sq = new Square(12);
Console.WriteLine($"Area of the square = {sq.GetArea()}");
}
}
// Output: Area of the square = 144
Metoda override
poskytuje novou implementaci metody zděděné ze základní třídy. Metoda, která je přepsána override
deklarací je známá jako přepisovaná základní metoda. Metoda override
musí mít stejný podpis jako přepsaná základní metoda. override
metody podporují kovariantní návratové typy. Konkrétně návratový override
typ metody může odvodit z návratového typu odpovídající základní metody.
Nelze přepsat ne virtuální nebo statickou metodu. Přepsaná základní metoda musí být virtual
, abstract
nebo override
.
Deklarace override
nemůže změnit přístupnost virtual
metody. Metoda override
i virtual
metoda musí mít stejný modifikátor úrovně přístupu.
Nelze použít new
, static
nebo virtual
modifikátory k úpravě override
metody.
Přepsání deklarace vlastnosti musí určovat přesně stejný modifikátor přístupu, typ a název jako zděděná vlastnost. Přepisování vlastností jen pro čtení podporuje kovariantní návratové typy. Přepsaná vlastnost musí být virtual
, abstract
nebo override
.
Další informace o tom, jak používat override
klíčové slovo, naleznete v tématu Správa verzí s přepsáním a novými klíčovými slovy a znalost, kdy použít přepsání a nová klíčová slova. Informace o dědičnosti naleznete v tématu Dědičnost.
Příklad
Tento příklad definuje základní třídu pojmenovanou Employee
a odvozenou třídu s názvem SalesEmployee
. Třída SalesEmployee
obsahuje dodatečné pole salesbonus
a přepíše metodu CalculatePay
tak, aby ji zohlednila.
class TestOverride
{
public class Employee
{
public string Name { get; }
// Basepay is defined as protected, so that it may be
// accessed only by this class and derived classes.
protected decimal _basepay;
// Constructor to set the name and basepay values.
public Employee(string name, decimal basepay)
{
Name = name;
_basepay = basepay;
}
// Declared virtual so it can be overridden.
public virtual decimal CalculatePay()
{
return _basepay;
}
}
// Derive a new class from Employee.
public class SalesEmployee : Employee
{
// New field that will affect the base pay.
private decimal _salesbonus;
// The constructor calls the base-class version, and
// initializes the salesbonus field.
public SalesEmployee(string name, decimal basepay, decimal salesbonus)
: base(name, basepay)
{
_salesbonus = salesbonus;
}
// Override the CalculatePay method
// to take bonus into account.
public override decimal CalculatePay()
{
return _basepay + _salesbonus;
}
}
static void Main()
{
// Create some new employees.
var employee1 = new SalesEmployee("Alice", 1000, 500);
var employee2 = new Employee("Bob", 1200);
Console.WriteLine($"Employee1 {employee1.Name} earned: {employee1.CalculatePay()}");
Console.WriteLine($"Employee2 {employee2.Name} earned: {employee2.CalculatePay()}");
}
}
/*
Output:
Employee1 Alice earned: 1500
Employee2 Bob earned: 1200
*/
specifikace jazyka C#
Další informace najdete v části Metody přepsání specifikace jazyka C#.
Další informace o kovariantových návratových typech najdete v poznámce k návrhu funkce.