博客
关于我
java简易通讯录,使用序列化实现,存入指定文件
阅读量:98 次
发布时间:2019-02-26

本文共 947 字,大约阅读时间需要 3 分钟。

Java程序实现通讯录功能

一、数据序列化存储

在本程序中,选择使用ArrayList来存储学生对象,这是一种常见的选择,因为它支持动态大小,元素可以随时添加、删除。通过ObjectOutputStreamObjectInputStream实现对象的序列化与反序列化功能,将程序运行中的数据存储到文本文件中。

二、文件操作机制

在主程序中,首先检查目标文件是否存在:

  • 如果文件不存在,则创建新文件。
  • 如果文件已存在,则使用ObjectInputStream反序列化读取已存储的数据,填充到ArrayList中。

随后进入主循环,用户可以通过菜单操作进行以下功能:

  • 添加新学生信息:读取输入数据,创建新学生对象并添加到ArrayList中,然后序列化写入文件。
  • 删除学生信息:通过输入姓名查找目标学生并删除。
  • 修改学生信息:通过输入姓名找到目标学生,逐一更新其相关属性。
  • 查找学生信息:用户可以选择通过姓名或地址进行查找。
  • 三、代码实现细节

    • 文件路径定义:使用静态常量Files定义文件路径,确保程序能够正确读写文件。
    • 输入流处理:使用Scanner读取用户输入,实现用户交互功能。
    • 异常处理:在文件操作和输入流处理中添加异常捕获,确保程序健壮性。

    四、优化与注意事项

    • 读写机制优化:在添加、删除、修改操作中,先通过ArrayList操作数据集合,再进行序列化写入文件,确保数据一致性。
    • 性能优化:在关闭流时使用try...finally结构,确保资源能被及时释放,避免资源泄漏。
    • 用户体验:通过菜单提示和输入提示信息,确保用户操作流程清晰,减少操作失误的几率。

    五、技术亮点

    • 对象序列化:通过Java的Serializable接口实现对象的序列化存储和读取,确保程序数据能够被准确恢复。
    • 文件操作:使用FileInputStreamFileOutputStream实现文件的读写操作,确保程序能够正确处理文件路径和权限问题。
    • 集合操作:使用ArrayList存储学生数据,支持动态增删改查,操作简便高效。

    六、扩展性分析

    该程序采用模块化设计,各功能模块独立且易于扩展。未来可以考虑增加更多的查询条件(如电话号码、邮箱地址等),或者实现数据的备份与恢复功能,进一步提升程序的实用性和可靠性。

    转载地址:http://bheu.baihongyu.com/

    你可能感兴趣的文章
    Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
    查看>>
    Mysql学习总结(65)——项目实战中常用SQL实践总结
    查看>>
    Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
    查看>>
    Mysql学习总结(67)——MYSQL慢查询日志
    查看>>
    Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
    查看>>
    Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
    查看>>
    Mysql学习总结(6)——MySql之ALTER命令用法详细解读
    查看>>
    Mysql学习总结(70)——MySQL 优化实施方案
    查看>>
    Mysql学习总结(71)——MySQL 重复记录查询与删除总结
    查看>>
    Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
    查看>>
    Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
    查看>>
    Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
    查看>>
    Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
    查看>>
    Mysql学习总结(78)——MySQL各版本差异整理
    查看>>
    Mysql学习总结(79)——MySQL常用函数总结
    查看>>
    Mysql学习总结(7)——MySql索引原理与使用大全
    查看>>
    Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
    查看>>
    Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
    查看>>
    Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
    查看>>
    Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
    查看>>