一、类的定义和对象的实例化
Python是一种面向对象的编程语言,类是其中重要的基础概念。定义一个类,需要使用关键字class
,代码如下:
class Person:
def __init__(self, name, age):
self.name = name
self.age = age
def hello(self):
print("Hello, my name is " + self.name)
上面的代码定义了一个Person
类,它有两个属性name
和age
,以及一个方法hello
。在方法中使用了self
关键字,表示这个方法是对象的方法,可以访问对象的属性。
下面是创建对象的代码,使用类名后跟一对括号即可:
p1 = Person("Alice", 25)
p2 = Person("Bob", 30)
我们使用类创建了两个对象p1
和p2
,分别赋予了初始的name
和age
属性。
二、继承
继承是面向对象编程中常用的概念之一,它允许一个类(称为子类)从另一个类(称为父类)中继承属性和方法。子类可以增加新的属性和方法,或者重载父类的方法。下面是一个继承的示例代码:
class Student(Person):
def __init__(self, name, age, grade):
super().__init__(name, age)
self.grade = grade
def study(self):
print(self.name + " is studying")
上面代码中,我们用Student
类继承了Person
类,增加了一个grade
属性和一个study
方法。
可以看到,子类的__init__
方法中调用了父类的__init__
方法,使用了super()
函数。这是因为子类中的__init__
方法会覆盖父类的__init__
方法,如果要继承父类的属性,就需要调用父类的__init__
方法。
三、多态
多态是指同一个方法或者属性在不同的类中有不同的实现。Python中的多态主要是通过duck typing实现,不关心对象的具体类型,只关注对象是否有某个特定的属性或方法。下面是一个多态的示例代码:
class Dog:
def __init__(self):
self.sound = "bark"
def speak(self):
print(self.sound)
class Cat:
def __init__(self):
self.sound = "meow"
def speak(self):
print(self.sound)
def speak(animal):
animal.speak()
speak(Dog())
speak(Cat())
上面的代码定义了Dog
和Cat
两个类,它们分别实现了speak
方法。另外还定义了一个speak
函数,它可以接受任何有speak
方法的对象,实现了多态。
四、封装
封装是面向对象编程中一个重要的概念,它指的是隐藏对象的属性和方法,只暴露必要的接口给外部使用。Python中通过命名约定实现封装,把属性和方法的名称以单下划线或者双下划线开头,即可实现封装。
class Car:
def __init__(self, make, model, year):
self._make = make
self.model = model
self.year = year
def _start(self):
print("start the engine")
def drive(self):
self._start()
print("drive the car")
mycar = Car("Toyota", "Camry", 2022)
mycar._start() # 仍然可以调用_start方法,但是不应该这样做,因为它是受保护的
上面的代码定义了一个Car
类,它有三个属性make
、model
和year
,以及一个_drive
方法和一个_start
方法。其中_start
方法前面加了一个单下划线,表示这个方法是受保护的,外部应该尽量避免使用。但是这并不是严格的限制,还是可以通过对象调用这个方法。另外,属性make
前面也加了一个单下划线,这也表示这个属性是受保护的。属性前面加双下划线的话,表示这个属性是私有的,外部无法访问。
五、类方法和静态方法
类方法和静态方法是Python中面向对象编程的扩展功能。类方法是指与类本身有关的方法,静态方法是指和类无关的方法。类方法和静态方法都是通过装饰器实现的。下面是一个类方法和一个静态方法的示例代码:
class MyClass:
count = 0
def __init__(self):
MyClass.count += 1
@classmethod
def get_count(cls):
return cls.count
@staticmethod
def say_hello():
print("Hello, world!")
obj1 = MyClass()
obj2 = MyClass()
print(MyClass.get_count())
MyClass.say_hello()
上面的代码定义了一个MyClass
类,它有一个属性count
和一个__init__
方法。另外还定义了一个类方法get_count
和一个静态方法say_hello
。其中类方法使用了@classmethod
装饰器,它可以访问类本身的属性。静态方法使用了@staticmethod
装饰器,它和类的关系非常松散,可以被类和对象直接调用。