应使用ArrayList替代数组存储员工对象,重写Employee的equals()和hashCode(),用Stream过滤查询,Iterator安全删除,HashMap按部门索引,Comparator链式排序,CSV文本持久化并异常兜底。

用 ArrayList 存员工对象,别用数组
硬编码数组长度会卡死后续增删——比如加个实习生就报 ArrayIndexOutOfBoundsException。直接上 ArrayList,动态扩容,增删都用 add()、remove(),不用自己搬数据。
关键点:
-
Employee类必须重写equals()和hashCode(),否则remove(new Employee("张三"))找不到原对象 - 查员工别用循环遍历,改用
stream().filter().findFirst(),语义清晰且可读性高 - 避免在遍历时调用
remove()—— 会抛ConcurrentModificationException,改用Iterator.remove()或收集待删 ID 再批量删
按部门分组用 Map> ,不是嵌套 if
想快速拿到“技术部所有人”,用 HashMap 做索引比每次遍历快得多。键是部门名(String),值是该部门员工列表(List)。
初始化和更新示例:
立即学习“Java免费学习笔记(深入)”;
Map> deptMap = new HashMap<>(); employeeList.forEach(e -> { deptMap.computeIfAbsent(e.getDept(), k -> new ArrayList<>()).add(e); });
注意:
- 别用
get(key)后判 null 再put,computeIfAbsent一行搞定,线程不安全但单机小系统够用 - 部门名为空时(
e.getDept() == null)会导致NullPointerException,插入前先做空校验 - 如果部门要支持修改,得同步更新
deptMap:先从旧部门列表删人,再往新部门加
排序查工资用 Comparator.comparing(),别手写 compare
按工资降序排员工?别写匿名类或 if-else 比较逻辑。Java 8+ 直接链式调用:
employeeList.sort(Comparator.comparingDouble(Employee::getSalary).reversed());
常见组合场景:
- 先按部门升序,同部门按工资降序:
Comparator.comparing(Employee::getDept).thenComparingDouble(Employee::getSalary).reversed() - 字段可能为 null?用
Comparator.nullsLast()包一层,比如nullsLast(comparing(Employee::getName)) - 排序后别反复调用
sort()—— 每次都是 O(n log n),查前 3 高薪员工用Collections.max()或流式limit(3)更省
持久化只存文本文件,用 ObjectOutputStream 反而埋雷
新手常想“序列化保存”,但 Serializable 对类结构极度敏感:改个字段类型、加个 transient,下次反序列化就 InvalidClassException。小型系统直接写 CSV 或简单 JSON 更稳。
推荐做法:
- 导出用
Files.write(Paths.get("emp.txt"), lines),每行一个员工,字段用|分隔(避开逗号和换行) - 导入时用
Files.lines(path).map(this::parseLine).collect(Collectors.toList()),parseLine()做字段拆分和类型转换(如Double.parseDouble()) - 别把密码、身份证等敏感字段写进文件;真要加密,用
Base64.getEncoder().encodeToString()简单混淆即可,别碰 AES 密钥管理
真正容易被忽略的是:文件路径没做异常包裹,FileNotFoundException 一出整个加载流程就断。所有 IO 操作外层必须包 try-catch 并给默认空集合兜底。










