class Person:
def __init__(self, name, age):
self.name = name
self.age = age
def create_person(name, age):
person = Person(name, age)
def greeting():
return f"Hello, my name is {person.name} and I'm {person.age} years old."
person.greeting = greeting
return person
# 使用工厂函数创建Person对象
p1 = create_person("Alice", 25)
p2 = create_person("Bob", 30)
# 调用greeting方法
print(p1.greeting()) # 输出 "Hello, my name is Alice and I'm 25 years old."
print(p2.greeting()) # 输出 "Hello, my name is Bob and I'm 30 years old."
在上面的代码中,我们定义了一个create_person函数作为工厂函数,它接受两个参数name和age,并返回一个Person对象。在函数内部,我们首先创建一个Person对象,然后定义一个greeting方法,并将其绑定到该对象上。最后,我们返回这个带有greeting方法的Person对象。
这样,我们就可以通过调用create_person函数来创建Person对象,而不需要直接实例化Person类。同时,由于greeting方法是动态添加到对象上的,因此每个对象都可以有自己的问候语。
create_person
函数是工厂函数。
工厂函数是一种设计模式,其核心思想在于提供一个创建对象的通用接口,将对象的实例化过程封装起来。在给定的Python示例中,create_person
函数就扮演了这样的角色。这个函数接收name
和age
两个参数,然后创建一个Person
类的实例,并为其添加一个greeting
方法。最后,这个带有新方法的Person
实例被返回。这个过程类似于工厂生产产品,因此得名“工厂函数”。
工厂函数的优点在于它降低了客户端代码与具体类之间的耦合度,提高了代码的复用性和可扩展性。通过这种方式,我们可以方便地创建一系列相关或依赖的对象,共享相同的创建逻辑,同时避免了重复代码。
总的来说,工厂函数是一种非常有用的设计模式,它通过封装对象的创建过程,使得代码更加模块化和易于管理。