分享一些Java面向对象的实际案例

简介: Java面向对象案例通过校园管理和电商系统,展现封装、继承、多态的协同:封装保护数据,继承复用代码,多态实现灵活扩展,贴近实际应用,体现OOP核心思想。(238字)

Java面向对象的实际案例能很好体现封装、继承、多态的结合使用,以下是几个贴近生活的场景案例:

案例1:校园人员管理系统(封装+继承+多态)

场景:学校有学生、老师两类人员,需统一管理基本信息,同时区分各自特性(学生有学号、老师有工号)。

// 1. 父类:封装共性属性和方法
class Person {
   
    private String name; // 封装姓名(私有属性)
    private int age;

    // 构造器初始化
    public Person(String name, int age) {
   
        this.name = name;
        this.age = age;
    }

    // getter/setter暴露接口(封装的体现)
    public String getName() {
    return name; }
    public int getAge() {
    return age; }

    // 共性方法:展示基本信息
    public void showInfo() {
   
        System.out.println("姓名:" + name + ",年龄:" + age);
    }
}

// 2. 子类1:学生(继承+扩展)
class Student extends Person {
   
    private String studentId; // 学生专属属性

    public Student(String name, int age, String studentId) {
   
        super(name, age); // 继承父类构造器
        this.studentId = studentId;
    }

    // 重写父类方法(多态基础)
    @Override
    public void showInfo() {
   
        super.showInfo(); // 复用父类逻辑
        System.out.println("身份:学生,学号:" + studentId);
    }

    // 学生专属方法
    public void study() {
   
        System.out.println(getName() + "正在学习");
    }
}

// 3. 子类2:老师(继承+扩展)
class Teacher extends Person {
   
    private String teacherId; // 老师专属属性

    public Teacher(String name, int age, String teacherId) {
   
        super(name, age);
        this.teacherId = teacherId;
    }

    // 重写父类方法(多态基础)
    @Override
    public void showInfo() {
   
        super.showInfo();
        System.out.println("身份:老师,工号:" + teacherId);
    }

    // 老师专属方法
    public void teach() {
   
        System.out.println(getName() + "正在讲课");
    }
}

// 4. 测试类(多态的实际应用)
public class SchoolSystem {
   
    public static void main(String[] args) {
   
        // 父类引用指向子类对象(多态)
        Person s = new Student("张三", 18, "2023001");
        Person t = new Teacher("李四", 35, "T001");

        // 调用同一方法,表现不同行为(多态特性)
        s.showInfo(); 
        // 输出:姓名:张三,年龄:18;身份:学生,学号:2023001
        t.showInfo(); 
        // 输出:姓名:李四,年龄:35;身份:老师,工号:T001

        // 子类专属方法需强转调用
        ((Student)s).study(); // 输出:张三正在学习
        ((Teacher)t).teach(); // 输出:李四正在讲课
    }
}

案例2:电商商品订单系统(接口+多态)

场景:订单可包含多种商品(手机、图书),需统一计算总价,每种商品有自己的计价逻辑。

// 1. 接口:定义商品的统一行为
interface Product {
   
    double getPrice(); // 计算价格
    String getName();  // 获取名称
}

// 2. 实现类1:手机(封装属性和计价逻辑)
class Phone implements Product {
   
    private String brand;
    private double price;
    private int storage; // 存储容量(影响价格)

    public Phone(String brand, double price, int storage) {
   
        this.brand = brand;
        this.price = price + (storage * 100); // 存储越大价格越高
    }

    @Override
    public double getPrice() {
    return price; }

    @Override
    public String getName() {
    return brand + "手机(" + storage + "G)"; }
}

// 3. 实现类2:图书(封装属性和计价逻辑)
class Book implements Product {
   
    private String title;
    private double price;
    private double discount; // 折扣(影响价格)

    public Book(String title, double price, double discount) {
   
        this.title = title;
        this.price = price * discount; // 折扣后价格
    }

    @Override
    public double getPrice() {
    return price; }

    @Override
    public String getName() {
    return title; }
}

// 4. 订单类(使用多态统一管理商品)
class Order {
   
    private Product[] products; // 订单中的商品(父类数组存子类对象)

    public Order(Product[] products) {
   
        this.products = products;
    }

    // 计算订单总价(多态:无需关心具体商品类型)
    public double calculateTotal() {
   
        double total = 0;
        for (Product p : products) {
   
            total += p.getPrice();
        }
        return total;
    }

    // 展示订单商品
    public void showProducts() {
   
        System.out.println("订单商品:");
        for (Product p : products) {
   
            System.out.println(p.getName() + ",单价:" + p.getPrice());
        }
    }
}

// 5. 测试类
public class OrderSystem {
   
    public static void main(String[] args) {
   
        // 创建不同商品(多态:统一用Product类型)
        Product p1 = new Phone("小米", 2999, 256); // 价格=2999+256*100=28599
        Product p2 = new Book("Java编程思想", 108, 0.8); // 价格=108*0.8=86.4

        // 生成订单
        Order order = new Order(new Product[]{
   p1, p2});
        order.showProducts();
        System.out.println("订单总价:" + order.calculateTotal()); // 输出:28685.4
    }
}

这些案例中,封装保证了数据安全(如私有属性通过方法访问),继承减少了代码重复(如学生/老师复用人员信息),多态实现了灵活扩展(如同一订单处理不同商品),完全贴合面向对象的设计思想。

相关文章
|
19天前
|
XML Java 开发者
springboot自动装配的基本原理
Spring Boot自动装配基于“约定大于配置”理念,通过@SpringBootApplication、@EnableAutoConfiguration与spring.factories机制,结合条件注解实现智能Bean加载。它根据依赖自动配置组件,大幅简化开发。其核心是AutoConfigurationImportSelector筛选符合条件的配置类,实现按需装配。开发者可专注业务,享受“开箱即用”的便捷体验。(238字)
|
2月前
|
JavaScript Java 关系型数据库
基于springboot的项目管理系统
本文探讨项目管理系统在现代企业中的应用与实现,分析其研究背景、意义及现状,阐述基于SSM、Java、MySQL和Vue等技术构建系统的关键方法,展现其在提升管理效率、协同水平与风险管控方面的价值。
|
2月前
|
搜索推荐 JavaScript Java
基于springboot的儿童家长教育能力提升学习系统
本系统聚焦儿童家长教育能力提升,针对家庭教育中理念混乱、时间不足、个性化服务缺失等问题,构建科学、系统、个性化的在线学习平台。融合Spring Boot、Vue等先进技术,整合优质教育资源,提供高效便捷的学习路径,助力家长掌握科学育儿方法,促进儿童全面健康发展,推动家庭和谐与社会进步。
|
Nacos 微服务 监控
Nacos:微服务架构中的“服务管家”与“配置中心”
Nacos是阿里巴巴开源的微服务“服务管家”与“配置中心”,集服务注册发现、动态配置管理、健康检查、DNS发现等功能于一体,支持多语言、多协议接入,助力构建高可用、易运维的云原生应用体系。
574 155
|
Java Spring 开发者
Spring Boot 常用注解详解:让你的开发更高效
本文详细解析Spring Boot常用注解,涵盖配置、组件、依赖注入、Web请求、数据验证、事务管理等核心场景,结合实例帮助开发者高效掌握注解使用技巧,提升开发效率与代码质量。
576 0
|
18天前
|
前端开发 Java 测试技术
MVC、MVP 与 MVVM:Android 架构演进之路
本文深度剖析Android架构演进史:从MVC、MVP到MVVM,再到2025年主流的MVI与分层架构。结合Jetpack、Compose与Kotlin协程,揭示架构本质是对复杂性的管理,展现从“上帝类”到响应式、声明式开发的工程进化之路。
128 0
|
19天前
|
架构师 IDE Java
【Java架构师】Maven中lombok那点事
SpringBoot项目中Lombok需在maven-compiler-plugin中配置`annotationProcessorPaths`,确保编译期生成getter/setter等方法;而`excludes`则在打包时排除Lombok依赖,减小体积,因运行时已无需该库。
94 0
|
2月前
|
JavaScript Java 关系型数据库
基于springboot的美食城服务管理系统
本系统基于Spring Boot、Java、Vue和MySQL技术,构建集消费者服务、商家管理与后台监管于一体的美食城综合管理平台,提升运营效率与用户体验。
|
6月前
|
人工智能 JSON Java
2025 年必知的 Java 高效开发实战:10 个让代码质量飙升的黄金法则详解
《Java高效开发实战:10个让代码质量飙升的黄金法则(2025版)》聚焦现代Java开发中的关键技术实践,涵盖日志优化、响应式编程、虚拟线程、资源管理、矢量API、防御编程、空值处理、领域驱动设计、WebFlux集成及AI辅助开发等内容。通过结构化日志、Reactor并行流、Project Loom虚拟线程等技术,显著提升性能与可维护性。结合Spring WebFlux和GitHub Copilot,助力构建高性能、智能化的应用系统。本书内容已在多家头部企业验证,适合开发者逐步落地,优化代码质量与开发效率。
259 2