内容:设计电话薄程序 (1)根据下面的描述设计类层次关系。 1)联系人信息有:姓名、电话、备注; 2)家人信息:还包括地址、固定电话; 3)朋友信息:还包括类别(同学、同事、其他朋友); 4)工作联系人信息:还包括公司、部门、职务。 (2)注意重写toString(),返回每类对象的全部信息 (3) 要求在父类中定义display()方法,此方法中将toString()结果输出值控台 (4)提供添加、删除、修改、查看指定成员、查看所有联系人信息等方法 (5)选做:图形用户界面、网络服务端 (6)使用Comparable或Comparator方法对联系人进行排序 (7)定义测试方法测试以上功能的java程序

时间: 2024-02-12 15:09:17 浏览: 18
根据题目描述,可以设计以下类层次关系: - 联系人信息类 Contact,包含姓名、电话、备注等基本信息,具有添加、删除、修改、查看指定成员、查看所有联系人信息等方法。 - 家人信息类 Family,继承自 Contact,增加了地址、固定电话等信息。 - 朋友信息类 Friend,继承自 Contact,增加了类别(同学、同事、其他朋友)等信息。 - 工作联系人信息类 WorkContact,继承自 Contact,增加了公司、部门、职务等信息。 在每个类中,需要实现重写 toString() 方法,返回每类对象的全部信息。此外,在父类 Contact 中定义 display() 方法,用于将 toString() 结果输出到控制台。 为了实现排序功能,可以在 Contact 类中实现 Comparable 接口或在外部编写 Comparator 实现类,并在 Contact 类中提供排序方法。 最后,可以编写测试方法,测试以上功能是否正常运行。可以使用图形用户界面或网络服务端,使用户更方便地使用程序。 以下是一个简单的实现示例(不包含图形用户界面或网络服务端): ```java import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; class Contact implements Comparable<Contact> { private String name; private String phone; private String remark; public Contact(String name, String phone, String remark) { this.name = name; this.phone = phone; this.remark = remark; } public String getName() { return name; } public String getPhone() { return phone; } public String getRemark() { return remark; } public void setName(String name) { this.name = name; } public void setPhone(String phone) { this.phone = phone; } public void setRemark(String remark) { this.remark = remark; } public void display() { System.out.println(toString()); } @Override public String toString() { return "姓名:" + name + ",电话:" + phone + ",备注:" + remark; } @Override public int compareTo(Contact o) { return this.name.compareTo(o.getName()); } public static void sort(ArrayList<Contact> list) { Collections.sort(list); } } class Family extends Contact { private String address; private String homePhone; public Family(String name, String phone, String remark, String address, String homePhone) { super(name, phone, remark); this.address = address; this.homePhone = homePhone; } public String getAddress() { return address; } public String getHomePhone() { return homePhone; } public void setAddress(String address) { this.address = address; } public void setHomePhone(String homePhone) { this.homePhone = homePhone; } @Override public String toString() { return super.toString() + ",地址:" + address + ",家庭电话:" + homePhone; } } class Friend extends Contact { private String type; public Friend(String name, String phone, String remark, String type) { super(name, phone, remark); this.type = type; } public String getType() { return type; } public void setType(String type) { this.type = type; } @Override public String toString() { return super.toString() + ",类型:" + type; } } class WorkContact extends Contact { private String company; private String department; private String job; public WorkContact(String name, String phone, String remark, String company, String department, String job) { super(name, phone, remark); this.company = company; this.department = department; this.job = job; } public String getCompany() { return company; } public String getDepartment() { return department; } public String getJob() { return job; } public void setCompany(String company) { this.company = company; } public void setDepartment(String department) { this.department = department; } public void setJob(String job) { this.job = job; } @Override public String toString() { return super.toString() + ",公司:" + company + ",部门:" + department + ",职务:" + job; } } public class PhoneBook { private ArrayList<Contact> contacts = new ArrayList<>(); public void add(Contact contact) { contacts.add(contact); } public void remove(Contact contact) { contacts.remove(contact); } public void update(Contact contact, String name, String phone, String remark) { contact.setName(name); contact.setPhone(phone); contact.setRemark(remark); } public Contact findByName(String name) { for (Contact contact : contacts) { if (contact.getName().equals(name)) { return contact; } } return null; } public void displayAll() { for (Contact contact : contacts) { contact.display(); } } public void sortByName() { Contact.sort(contacts); } public void sortByPhone() { Collections.sort(contacts, new Comparator<Contact>() { @Override public int compare(Contact o1, Contact o2) { return o1.getPhone().compareTo(o2.getPhone()); } }); } public static void main(String[] args) { PhoneBook phoneBook = new PhoneBook(); // 添加联系人 phoneBook.add(new Family("张三", "123456789", "家人", "北京市", "010-12345678")); phoneBook.add(new Friend("李四", "987654321", "朋友", "同学")); phoneBook.add(new WorkContact("王五", "2468101214", "工作", "ABC公司", "技术部", "工程师")); phoneBook.add(new Contact("赵六", "5555555", "其他")); // 显示所有联系人 System.out.println("所有联系人:"); phoneBook.displayAll(); // 修改联系人 Contact contact = phoneBook.findByName("张三"); if (contact != null) { phoneBook.update(contact, "张三", "123456789", "家人,北京市昌平区"); } // 按姓名排序并显示 phoneBook.sortByName(); System.out.println("按姓名排序后:"); phoneBook.displayAll(); // 按电话排序并显示 phoneBook.sortByPhone(); System.out.println("按电话排序后:"); phoneBook.displayAll(); } } ``` 以上代码实现了电话薄程序的大部分功能,包括添加、删除、修改、查找、排序等。其中,使用了 ArrayList 来存储联系人信息,使用了 Comparable 和 Comparator 接口来实现排序功能。在测试方法中,演示了如何添加、修改、查找、排序联系人,并将联系人信息输出到控制台。

相关推荐

最新推荐

recommend-type

C语言课程设计-电话簿管理系统

用C语言实现的简单的电话簿管理系统,其中包含完整的代码以及程序的流程框图
recommend-type

C语言实现电话簿管理系统

主要为大家详细介绍了C语言实现电话簿管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

电话簿管理系统(c语言课程设计)

电话簿管理系统(c语言课程设计)电话簿管理系统(c语言课程设计)电话簿管理系统(c语言课程设计)电话簿管理系统(c语言课程设计)
recommend-type

数据结构课程设计散列表电话号码查询系统

3.1采用类c语言定义相关的数据类型 函数有: void getin() //输入信息...#define MAXSIZE 20 //电话薄记录数量 #define MAX_SIZE 20 //人名的最大长度 #define HASHSIZE 53 //定义表长 int Hash1(NA str) //散列函数
recommend-type

【图像压缩】 GUI矩阵的奇异值分解SVD灰色图像压缩【含Matlab源码 4359期】.zip

Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描视频QQ名片; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

云原生架构与soa架构区别?

云原生架构和SOA架构是两种不同的架构模式,主要有以下区别: 1. 设计理念不同: 云原生架构的设计理念是“设计为云”,注重应用程序的可移植性、可伸缩性、弹性和高可用性等特点。而SOA架构的设计理念是“面向服务”,注重实现业务逻辑的解耦和复用,提高系统的灵活性和可维护性。 2. 技术实现不同: 云原生架构的实现技术包括Docker、Kubernetes、Service Mesh等,注重容器化、自动化、微服务等技术。而SOA架构的实现技术包括Web Services、消息队列等,注重服务化、异步通信等技术。 3. 应用场景不同: 云原生架构适用于云计算环境下的应用场景,如容器化部署、微服务
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。