应使用ArrayList替代硬编码数组,Contact需重写equals()和hashCode(),遍历时删除须用Iterator.remove()或倒序循环,搜索用stream().filter(),存储优选JSON或CSV而非ObjectOutputStream。
ArrayList 存通讯录对象,别用数组硬编码
硬写 String[] names 或 Contact[] list 会导致增删困难、长度固定。真实场景下,联系人数量动态变化,必须用可变集合。直接上 ArrayList,Contact 是你自己定义的类,含 name、phone、email 等字段。
注意点:
Contact 类必须重写 equals() 和 hashCode(),否则 list.remove(contact) 可能失效(默认比较引用)ArrayList 时直接调用 remove(),会抛 ConcurrentModificationException;改用 Iterator.remove() 或倒序 for 循环new ArrayList(100) —— 容量设太大浪费内存,设太小频繁扩容(每次 1.5 倍)影响性能;默认构造即可stream().filter(),不是手写 for用户输入“张三”,你要返回所有匹配的 Contact。别再写三层 for 循环加 if 判断——Java 8+ 就该用流式处理,语义清晰且不易出错。
示例代码片段:
list.stream()
.filter(c -> c.getName().contains(input))
.collect(Collectors.toList());
关键细节:
contains() 而非 equals(),支持模糊搜索;若要精确匹配,换成 c.getName().equals(input)
Map> 做索引,但得同步维护一致性stream() 是惰性求值,不触发 collect() 就不会执行;调试时别只写 filter 就以为有结果ObjectOutputStream?风险高,改用 JSON 或 CSV新手常想“序列化整个 ArrayList 到文件”,但 ObjectOutputStream 生成的二进制格式不可读、跨 JDK 版本不兼容、反序列化有安全风险(如恶意 payload),纯属自找麻烦。
更务实的做法:
Files.write() 写 CSV,每行 张三,13800138000,zhang@xx.com,用 String.split(",") 解析com.fasterxml.jackson.core:jackson-databind,调 new ObjectMapper().writeValue(file, list) 输出 JSON,结构清晰、易调试、方便后续扩展如果你用控制台模拟界面(比如打印全部联系人列表),删完忘了调 System.out.println(list),就会以为“删没成功”。这不是集合问题,是逻辑断点缺失。
真正要注意的是:
new Ar
rayList(original))ContactManager 类,删完应返回 boolean success 或抛明确异常(如 ContactNotFoundException),别让调用方靠“没报错”来判断成功ArrayList 不是线程安全的,得换 Collections.synchronizedList() 或 CopyOnWriteArrayList,但后者写多读少时性能差Contact 实例创建后有没有被正确加入集合?删除时是不是删了另一个新 new 出来的临时对象?这些隐式引用关系,比 for 循环少个括号还难 debug。