【100天精通python】Day13:面向对象编程_多态和封装,实战模拟电影院的自动售票机选票页面

简介: 【100天精通python】Day13:面向对象编程_多态和封装,实战模拟电影院的自动售票机选票页面

在 Python 中,多态和封装是面向对象编程的两个重要概念。

1 多态(Polymorphism)

       多态是指同一个方法可以根据不同的对象类型产生不同的行为。在 Python 中,多态是通过方法的动态绑定实现的,即方法的调用在运行时根据对象的类型确定。这使得代码更加灵活,可以处理不同类型的对象而无需关心对象的具体类型。

class Animal:
    def speak(self):
        pass
class Dog(Animal):
    def speak(self):
        return "Woof!"
class Cat(Animal):
    def speak(self):
        return "Meow!"
def make_sound(animal):
    return animal.speak()
dog = Dog()
cat = Cat()
print(make_sound(dog))  # 输出:Woof!
print(make_sound(cat))  # 输出:Meow!

在上面的示例中,我们定义了一个 Animal 基类和两个子类 Dog 和 Cat,它们都重写了基类的 speak 方法。然后,我们定义了一个 make_sound 函数,它接受一个 Animal 类型的参数,并调用其 speak 方法。当我们传入不同类型的对象(Dog 和 Cat)给 make_sound 函数时,由于多态的特性,该函数会根据传入的对象类型调用不同的 speak 方法,实现了多态性。

2 封装(Encapsulation)

        封装是指将数据和对数据的操作封装在一个对象中,对外部隐藏内部的实现细节。在 Python 中,封装是通过将数据和方法定义在类中,并使用访问修饰符来控制外部对内部数据的访问权限实现的。封装可以确保数据的安全性和完整性,并提供了良好的抽象,使得外部代码只能通过类的公共接口来访问和操作数据。

示例:

class Car:
    def __init__(self, make, model):
        self._make = make
        self._model = model
        self._speed = 0
    def accelerate(self, amount):
        self._speed += amount
    def brake(self, amount):
        self._speed -= amount
    def get_speed(self):
        return self._speed
car = Car("Toyota", "Corolla")
car.accelerate(50)
print(car.get_speed())  # 输出:50
# 尝试直接访问对象的内部数据,将会得到错误
# print(car._speed)  # 错误:AttributeError: 'Car' object has no attribute '_speed'

在上面的示例中,我们定义了一个 Car 类,封装了车辆的数据和方法。使用私有变量(以单下划线开头)来表示内部数据,以及公共方法来操作数据。这样,外部代码无法直接访问对象的内部数据,只能通过公共方法来访问和操作数据,实现了封装性。

3 总结

多态和封装是面向对象编程中的两个重要概念。

多态使得相同的方法能够处理不同类型的对象,增加了代码的灵活性和可重用性。

封装将数据和方法封装在对象中,对外部隐藏内部实现细节,确保了数据的安全性和完整性,并提供了良好的抽象。

在 Python 中,我们可以通过继承和访问修饰符来实现多态和封装的特性。

4 实战:模拟电影院的自动售票机选票页面

为了模拟电影院的自动售票机选票页面,我们可以创建一个简单的 Python 程序,让用户选择电影、座位和购票数量。以下是一个基本示例:

class Movie:
    def __init__(self, title, showtimes, available_seats):
        self.title = title
        self.showtimes = showtimes
        self.available_seats = available_seats
class TicketMachine:
    def __init__(self):
        self.movies = []
        self.current_movie = None
        self.current_showtime = None
        self.selected_seats = []
    def add_movie(self, movie):
        self.movies.append(movie)
    def show_movies(self):
        print("Movies available:")
        for idx, movie in enumerate(self.movies, start=1):
            print(f"{idx}. {movie.title}")
    def select_movie(self, movie_idx):
        self.current_movie = self.movies[movie_idx - 1]
        self.show_movie_showtimes()
    def show_movie_showtimes(self):
        print(f"Showtimes for '{self.current_movie.title}':")
        for idx, showtime in enumerate(self.current_movie.showtimes, start=1):
            print(f"{idx}. {showtime}")
    def select_showtime(self, showtime_idx):
        self.current_showtime = self.current_movie.showtimes[showtime_idx - 1]
        self.show_available_seats()
    def show_available_seats(self):
        print("Available seats:")
        for seat in self.current_movie.available_seats:
            if seat not in self.selected_seats:
                print(seat)
    def select_seats(self, seats):
        self.selected_seats.extend(seats)
    def buy_tickets(self):
        total_price = len(self.selected_seats) * 10  # 假设每张票价格为10元
        print(f"Total price: {total_price} yuan")
        self.current_movie.available_seats = [seat for seat in self.current_movie.available_seats if seat not in self.selected_seats]
        print("Tickets purchased successfully!")
if __name__ == "__main__":
    # 创建电影对象
    movie1 = Movie("Movie 1", ["10:00 AM", "2:00 PM", "6:00 PM"], ["A1", "A2", "B1", "B2"])
    movie2 = Movie("Movie 2", ["11:00 AM", "3:00 PM", "7:00 PM"], ["C1", "C2", "D1", "D2"])
    # 创建售票机对象
    ticket_machine = TicketMachine()
    ticket_machine.add_movie(movie1)
    ticket_machine.add_movie(movie2)
    # 用户选票流程
    print("Welcome to the Ticket Machine!")
    ticket_machine.show_movies()
    movie_choice = int(input("Select a movie (enter the movie number): "))
    ticket_machine.select_movie(movie_choice)
    showtime_choice = int(input("Select a showtime (enter the showtime number): "))
    ticket_machine.select_showtime(showtime_choice)
    print("Select your seats (enter seat numbers separated by spaces):")
    seats_choice = input().split()
    ticket_machine.select_seats(seats_choice)
    ticket_machine.buy_tickets()

在python IDLE中创建 tickets.py 文件,运行上面代码,结果如下:

5eda4b94859f4e479d6512c01910a838.png

请注意,以上示例是一个简单的模拟,并没有实际购票功能,仅用于展示流程。在实际应用中,我们需要与数据库或其他系统进行交互,并添加更多复杂的功能,如用户登录、支付等。此示例仅供参考,您可以根据实际需求进行扩展。  


目录
相关文章
|
6月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
773 7
|
6月前
|
数据采集 Web App开发 数据安全/隐私保护
实战:Python爬虫如何模拟登录与维持会话状态
实战:Python爬虫如何模拟登录与维持会话状态
|
6月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
509 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
6月前
|
数据采集 监控 数据库
Python异步编程实战:爬虫案例
🌟 蒋星熠Jaxonic,代码为舟的星际旅人。从回调地狱到async/await协程天堂,亲历Python异步编程演进。分享高性能爬虫、数据库异步操作、限流监控等实战经验,助你驾驭并发,在二进制星河中谱写极客诗篇。
Python异步编程实战:爬虫案例
|
6月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
1271 1
Python API接口实战指南:从入门到精通
|
6月前
|
存储 分布式计算 测试技术
Python学习之旅:从基础到实战第三章
总体来说,第三章是Python学习路程中的一个重要里程碑,它不仅加深了对基础概念的理解,还引入了更多高级特性,为后续的深入学习和实际应用打下坚实的基础。通过这一章的学习,读者应该能够更好地理解Python编程的核心概念,并准备好应对更复杂的编程挑战。
198 12
|
6月前
|
存储 数据采集 监控
Python文件操作全攻略:从基础到高级实战
本文系统讲解Python文件操作核心技巧,涵盖基础读写、指针控制、异常处理及大文件分块处理等实战场景。结合日志分析、CSV清洗等案例,助你高效掌握文本与二进制文件处理,提升程序健壮性与开发效率。(238字)
541 1
|
6月前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
1133 1
|
6月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
650 0

推荐镜像

更多
下一篇
开通oss服务