Amalan terbaik untuk menulis semula fungsi: Pastikan enkapsulasi: hanya tulis semula tingkah laku yang perlu diubah. Gunakan anotasi ganti: nyatakan secara eksplisit kaedah kelas induk mengatasi. Ikut prinsip penggantian Liskov: objek kelas terbitan boleh menggantikan objek kelas induk tanpa mengubah tingkah laku program. Elakkan kaedah maya: mengatasi adalah lebih baik dan menyediakan semakan jenis yang lebih kukuh.
Amalan terbaik untuk penulisan semula fungsi: melepaskan potensi pewarisan dan meningkatkan kebolehselenggaraan kod
Dalam pengaturcaraan berorientasikan objek, warisan ialah mekanisme yang berkuasa untuk mencapai penggunaan semula kod dan polimorfisme. Melalui fungsi mengatasi, tingkah laku kelas induk boleh dilanjutkan untuk memenuhi keperluan khusus kelas terbitan. Mengikuti amalan terbaik adalah penting untuk memastikan keberkesanan mengatasi fungsi dan kebolehselenggaraan kod.
1. Pastikan enkapsulasi
Apabila menulis semula fungsi, enkapsulasi pelaksanaan kelas induk harus dikekalkan. Ini bermakna mengatasi hanya tingkah laku yang perlu diubah, tanpa melanggar pelaksanaan asal. Contohnya:
class Animal: def make_sound(self): return "Generic animal sound" class Dog(Animal): def make_sound(self): return "Woof!"
2. Gunakan anotasi ganti
Dalam kelas terbitan yang menggantikan fungsi, gunakan anotasi @override
untuk menunjukkan dengan jelas bahawa kaedah kelas induk sedang ditindih. Ini membantu mendokumentasikan kod anda dan mengelakkan penulisan ganti secara tidak sengaja. Contohnya: @override
注释明确表明正在重写父类方法。这有助于文档化代码,并避免意外覆盖。例如:
@override class Dog(Animal): def make_sound(self): return "Woof!"
3. 遵循 Liskov 替换原则
函数重写应遵循 Liskov 替换原则,即子类对象必须能够替换其父类对象,并且程序行为不会改变。这确保了派生类的行为与预期一致。例如:
class Shape: def calculate_area(self): raise NotImplementedError() class Rectangle(Shape): def __init__(self, width, height): self.width = width self.height = height def calculate_area(self): return self.width * self.height
4. 避免虚方法
在大多数情况下,使用重写比虚方法更可取。重写提供更强的类型检查,并且允许子类在运行时确定父类的实现。例如:
class Animal: def make_sound(self): pass class Dog(Animal): def make_sound(self): return "Woof!"
实战案例
以下是一个实战案例,展示了如何使用函数重写扩展父类的行为:
考虑一个 Employee
父类,其中包含一个 calculate_salary
方法。现在,我们需要创建一个 Manager
派生类,它具有自己的 calculate_bonus
方法。
class Employee: def __init__(self, name, salary): self.name = name self.salary = salary def calculate_salary(self): return self.salary class Manager(Employee): def __init__(self, name, salary, bonus): super().__init__(name, salary) self.bonus = bonus def calculate_salary(self): total_salary = super().calculate_salary() + self.bonus return total_salary
通过重写 calculate_salary
方法,Manager
类可以计算包含奖金在内的总工资,而无需破坏 Employee
rrreee
Pekerja
, yang mengandungi kaedah calculate_gaji
. Sekarang, kita perlu mencipta kelas terbitan Manager
yang mempunyai kaedah calculate_bonus
sendiri. 🎜rrreee🎜Dengan mengatasi kaedah calculate_gaji
, kelas Manager
boleh mengira jumlah gaji termasuk bonus tanpa memusnahkan gaji asal dalam kelas Employee
capai . 🎜Atas ialah kandungan terperinci Amalan terbaik untuk penulisan semula fungsi: melepaskan potensi pewarisan dan meningkatkan kebolehselenggaraan kod. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!