如何在实际项目中运用面向对象的三大特征

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 本文结合真实项目场景,详解面向对象三大特征:封装控制数据访问,继承复用共性代码,多态实现统一接口下的多样化行为。通过用户管理、电商商品、支付系统等案例,展示如何抽象共性、隔离变化、提升复用,构建灵活、可维护的高质量代码体系。

在实际项目中运用面向对象的三大特征(封装、继承、多态),核心是通过“抽象共性、隔离变化、提升复用”来设计灵活、可维护的代码。以下结合真实项目场景,说明具体运用方式:

一、封装:控制数据访问,隔离实现细节

核心目标:让类的“内部实现”与“外部使用”解耦,外部只能通过指定接口操作,避免误修改或依赖细节。

实际项目场景:用户信息管理模块

  • 问题:用户的密码、手机号等敏感信息不能直接暴露,且修改时需校验格式(如手机号必须11位)。
  • 封装运用
    1. 将用户的passwordphone等属性设为private,禁止外部直接读写。
    2. 提供publicsetPhone(String phone)方法,在方法内添加校验逻辑(如正则匹配手机号格式),不符合则抛异常。
    3. 提供getPhone()方法时,可返回脱敏后的结果(如138****5678),保护隐私。
public class User {
   
    private String phone; // 私有属性,外部无法直接访问
    private String password;

    // 封装手机号设置逻辑(含校验)
    public void setPhone(String phone) {
   
        if (phone.matches("^1[3-9]\\d{9}$")) {
    // 校验手机号格式
            this.phone = phone;
        } else {
   
            throw new IllegalArgumentException("手机号格式错误");
        }
    }

    // 封装手机号获取逻辑(脱敏)
    public String getPhone() {
   
        if (phone == null) return null;
        return phone.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2");
    }
}
  • 效果:外部只能通过规范的方法操作数据,避免非法值传入,且后续若修改校验规则(如增加国际手机号支持),只需修改setPhone方法,不影响外部调用。

二、继承:复用共性代码,扩展专属功能

核心目标:提取多个类的共性属性和方法到父类,子类专注于实现自身特有的逻辑,减少重复代码。

实际项目场景:电商系统的“商品”模块

  • 问题:系统中有“实体商品”(如手机,需计算运费)和“虚拟商品”(如充值卡,无需运费),两者都有名称、价格等共性,但运费计算逻辑不同。
  • 继承运用
    1. 定义父类Product,封装共性:nameprice属性,以及getInfo()(返回商品基本信息)等通用方法。
    2. 子类PhysicalProduct继承Product,新增weight属性和calculateFreight()(按重量算运费)方法。
    3. 子类VirtualProduct继承Product,无需重写运费方法(或默认返回0),新增validateCode()(校验激活码)方法。
// 父类:封装共性
public class Product {
   
    protected String name; // 受保护属性,子类可访问
    protected double price;

    public Product(String name, double price) {
   
        this.name = name;
        this.price = price;
    }

    public String getInfo() {
   
        return "商品:" + name + ",价格:" + price;
    }
}

// 子类1:实体商品(扩展运费逻辑)
public class PhysicalProduct extends Product {
   
    private double weight; // 专属属性

    public PhysicalProduct(String name, double price, double weight) {
   
        super(name, price); // 复用父类构造器
        this.weight = weight;
    }

    // 专属方法:计算运费
    public double calculateFreight() {
   
        return weight * 8; // 每公斤8元运费
    }
}
  • 效果:共性代码(如商品名称、价格管理)只写一次,子类仅关注差异点,后续新增“服务类商品”时,只需继承Product并扩展专属逻辑即可。

三、多态:统一接口,适配不同实现

核心目标:用父类/接口定义统一规范,子类实现具体逻辑,调用时无需关心子类类型,直接通过父类引用操作,提升代码灵活性。

实际项目场景:支付系统的“支付渠道”模块

  • 问题:系统需支持微信、支付宝、银联等多种支付方式,每种方式的支付流程(如签名、接口调用)不同,但上层业务只需调用“支付”动作。
  • 多态运用
    1. 定义接口Payment,声明统一方法pay(double amount)(支付金额)。
    2. 不同支付渠道(WeChatPaymentAlipayPayment)实现Payment接口,各自实现pay方法(如微信调用微信支付API,支付宝调用支付宝API)。
    3. 业务层(如订单模块)只需接收Payment类型的参数,调用pay方法即可,无需修改代码就能切换支付方式。
// 接口:定义统一支付规范
public interface Payment {
   
    boolean pay(double amount); // 返回支付是否成功
}

// 实现类1:微信支付
public class WeChatPayment implements Payment {
   
    @Override
    public boolean pay(double amount) {
   
        System.out.println("调用微信支付接口,扣除" + amount + "元");
        return true; // 实际项目中需根据接口返回判断
    }
}

// 实现类2:支付宝支付
public class AlipayPayment implements Payment {
   
    @Override
    public boolean pay(double amount) {
   
        System.out.println("调用支付宝支付接口,扣除" + amount + "元");
        return true;
    }
}

// 业务层:订单支付(依赖接口,不依赖具体实现)
public class OrderService {
   
    // 传入Payment接口,支持任何实现类
    public void payOrder(Payment payment, double amount) {
   
        if (payment.pay(amount)) {
   
            System.out.println("订单支付成功");
        } else {
   
            System.out.println("订单支付失败");
        }
    }
}

// 调用示例
public class Test {
   
    public static void main(String[] args) {
   
        OrderService service = new OrderService();
        // 微信支付
        service.payOrder(new WeChatPayment(), 199.9);
        // 支付宝支付(无需修改OrderService代码)
        service.payOrder(new AlipayPayment(), 299.9);
    }
}
  • 效果:新增支付渠道(如银联)时,只需新增一个Payment实现类,业务层代码无需修改,符合“开闭原则”(对扩展开放,对修改关闭)。

三大特征的协同运用:以“权限管理系统”为例

  1. 封装User类封装用户的角色、权限列表,通过hasPermission(String permission)方法判断是否有权限(隐藏权限校验细节)。
  2. 继承:定义BaseUser父类封装共性(用户名、密码),AdminUserNormalUser子类继承后,分别扩展“管理权限”“普通用户权限”。
  3. 多态:业务层通过BaseUser父类引用接收用户对象,调用hasPermission方法时,自动适配子类的权限逻辑(管理员有全部权限,普通用户有限制)。

总结:核心原则

  • 封装:记住“属性私有,方法公开”,控制数据访问边界。
  • 继承:避免过度继承(如超过3层),优先用“组合”代替继承(如A类需要B类的功能,可在A中定义B的对象,而非继承B)。
  • 多态:依赖抽象(接口/父类)而非具体实现,让代码更易扩展。

通过这三大特征的配合,能设计出低耦合、高复用的代码,尤其在中大型项目中,可显著降低维护成本。

相关文章
|
机器学习/深度学习 人工智能 运维
什么是AIOps智能运维?
AIOps(智能运维)是一种利用人工智能和机器学习技术的软件,用于实时分析和处理业务和运营数据,以提供规范性和预测性答案。它通过收集和汇总大量数据,并使用智能筛选和识别重要事件和模式,帮助团队快速解决问题并避免事件发生。AIOps不依赖于人为指定规则,而是通过机器学习算法自动学习和提炼规则。它可以分析异常告警、故障分析、趋势预测等,并在某些情况下自动解决问题。AIOps的团队包括SRE团队、开发工程师团队和算法工程师团队,他们在AIOps相关工作中扮演不同的角色。
|
数据采集 算法 机器人
软件体系结构 - 调度算法(3) 单调速率调度算法
【4月更文挑战第19天】软件体系结构 - 调度算法(3) 单调速率调度算法
580 0
|
7月前
|
传感器 运维 监控
基于北斗和蓝牙beacon的室内北斗定位系统从原理到应用全面详解(一)
本文介绍基于北斗与蓝牙beacon的室内定位系统,融合卫星与蓝牙技术优势,实现室内外无缝覆盖、多精度分级、低成本部署及多功能扩展,适用于工厂、园区等全域定位场景。
|
4月前
|
人工智能 前端开发 安全
从部署到落地:AI编程辅助工具全流程实操指南
在AI编程工具同质化日益明显的当下,一款开源可扩展、安全可控的AI编程辅助工具,成为适配个人开发者与中小团队的实用选择。它并非单纯的代码生成器,而是覆盖需求拆解、编码开发、代码Review全流程的AI研发基础设施,能够有效降低重复编码成本,提升开发效率。本文结合笔者两个多月的实操经验,分享其核心使用场景、可复现实战案例及客观使用心得
472 11
|
7月前
|
Java 程序员 持续交付
Git 从入门到进阶:常用命令与高级用法全解析
本文系统梳理Git常用命令与高级技巧,涵盖初始化、分支管理、变基、储藏、标签、差异对比、二分查找及reflog等核心功能,结合最佳实践与避坑指南,助你从入门到精通,提升代码管理与团队协作效率。
788 74
|
7月前
|
安全 C++
C++ 智能指针详解:从原理到实践
深入解析 C++ 智能指针的原理与用法,掌握 unique_ptr、shared_ptr、weak_ptr 的最佳实践
|
7月前
|
人工智能 Java 程序员
程序员的薪资确实不低,但他们为什么还不快乐?
知乎热议:“程序员高薪为何仍焦虑?”高薪背后是职业天花板、35岁危机、持续学习压力与高强度工作。他们缺的不是钱,而是安全感与可持续的职业未来。
|
7月前
|
JSON 数据挖掘 API
闲鱼商品列表API秘籍!轻松获取列表数据
闲鱼商品列表API(Goodfish.item_list)基于RESTful架构,支持GET请求,返回JSON格式数据,可获取商品标题、价格、图片、卖家信息等,适用于电商比价与数据分析,助力开发者高效集成闲鱼商品数据。
|
机器学习/深度学习 人工智能 运维
如何通过AI 全面提升运维效率?选型宝分享AIOps实战案例
前言 运维,是企业IT最基础的工作,也是痛点、槽点最多的工作。海量的数据、频繁的报警、艰难的排障、无情的投诉,足以让运维工程师们感到崩溃和绝望…… Gartner在ITOA (IT Operations Analytics IT运营分析)的基础上,提出了AIOps的概念。
3763 0