C#通讯录管理系统课程设计

C#通讯录管理系统课程设计
C#通讯录管理系统课程设计

课程设计报告

课程名称:C#.NET程序设计

设计题目:通讯录管理系统

学生班级:

学生姓名:

指导教师:

完成日期:

数学与计算机系

课程设计项目研究报告

目录

第 1 章项目简介 (1)

1.1 项目名称 (1)

1.2 开发人员 (1)

1.3 指导教师 (1)

第 2 章项目研究意义 (1)

2.1 课程设计概述 (1)

2.2 设计构思 (1)

2.3 研究意义 (2)

第 3 章模块分析及设计 (2)

3.1系统功能结构图 (2)

3.2系统数据流程图 (3)

第4 章数据库设计 (4)

4.1数据库需求分析 (4)

4.2 E-R图 (4)

4.3 数据表设计 (4)

4.3.1登录用户信息表: (5)

4.3.2通讯录信息表 (5)

第5 章课程设计项目进度表 (6)

第6 章课程设计任务分配表 (6)

第7 章达到的效果 (6)

7.1 程序设计思想 (6)

7.2 程序最终实现结果: (7)

第8 章重要的源程序 (10)

第10 章参考文献 (20)

第 1 章项目简介

1.1 项目名称

通讯录管理系统

1.2 开发人员

1.3 指导教师

第 2 章项目研究意义

2.1 课程设计概述

日益繁多的人际交往使得我们很难搞清楚与每个人之间的联系方式,特别是对于做经常出差的人来说更是难,所以通讯录能够便捷的给我们带来所需要的相关信息。而随着计算机的普及,人们的生活摆脱了传统式的记事本、电话簿,越来越多的靠计算机来帮助人们记住这些事情,极其简便。这就需要有一个使用的通讯录管理系统,用户可以方便的通过自己电脑的通讯录管理系统,来随时查阅自己所需要的信息,而不必再大费周折去翻开那繁琐的记事本。

通讯录管理系统主要分为五个功能模块:用户登录与注册、用户查询、添加记录、修改记录、删除记录。这些功能可以够基本实现你的应用需求。

2.2 设计构思

通讯录管理系统功能需求分析:

用户登录与注册:实现不同用户的注册跟登录通讯录。

显示全部:实现用户对存在于数据库中的数据显示,方便用户了解数据存储情况。

查找记录:实现用户在本软件数据库中查找自己需要的数据功能。

地址。

修改记录:用户对数据库中已存在的记录进行修改,然后保存已经修改过的数据。

删除记录:用户对数据库中已经存在的记录进行行删除操作。

2.3 研究意义

通讯录管理系统是一个专门针对储存用户联系方式以及一些简单个人信息的实用管理系统,它方便了用户对众多客户、朋友、同事等个人信息的储存和快速查阅的功能,大大减少了查找过程的时间。

第 3 章模块分析及设计

3.1系统功能结构图

3.2系统数据流程图

第4 章数据库设计

4.1数据库需求分析

针对通讯录管理系统,分别对用户登录、添加通讯录和查找、删除以及修改数据进行详细的调研和分析,总结出如下的需求信息:

1.每条原始记录要有姓名、生日、电话、邮箱、地址信息,其中姓名不能为空。

2.保证查询到的数据与姓名相一致

3.根据相应姓名删除对应的全部数据

4.2 E-R图

4.3 数据表设计

·数据库名称:通讯录管理系统,共有2个表:

1、用户表(Users)

2、通讯录联系表(Contact)

4.3.1登录用户信息表:

4.3.2通讯录信息表

第5 章课程设计项目进度表

第6 章课程设计任务分配表

第7 章达到的效果

7.1 程序设计思想

通讯录管理系统设计,它的内容对于计算机来说是至关重要的,通讯录管理系统为计算机的使用者提供充足的信息和快捷的查询手段。用C#语言构建的通讯录管理系统设计,通过课上学到的和查阅一些文献的一些关于结构体、函数以及循环函数的运用和字符串的处理等基本知识可以初步的实现通讯录的显示、添加、查找、删除、修改等通讯录简单而用的一些实用的功能,给人们带来更多的方便。本管理系统设计合理、操作方便、运行稳定、功能完备,具有较高的实用价值

7.2 程序最终实现结果:

通讯录管理系统的登录界面:

当用户登录成功时,界面跳转到主界面:

如果是新用户则单击登录界面的注册按钮跳转到注册界面:

在主界面中分别设有显示全部、添加、查找、修改、删除、退出系统按钮,点击显示全部按钮则将显示数据库中的全部成员:

单击添加菜单时,则将显示所要添加的内容信息,并更新到数据库中:

单击查找菜单,按姓名查找方式,输入想要查找的名字,点击查找按钮并清空文本框:

单击修改菜单,以姓名为主健进行修改相关数据并清空输入框信息:

单击删除菜单,以姓名为查找方式进行查找删除并将数据库更新:

单击退出系统,则将关闭所有的窗口。

第8 章重要的源程序

连接数据库:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data.SqlClient;

namespace tong_xun_lu_guan_li

{

public static class DBClass

{

public static String strConn = "Data source=SKQ3HEOVTLD8XZY\\SQLEXPRESS;Database= 通讯录管理系统;integrated security = SSPI";

public static SqlConnection conn = new SqlConnection(strConn);

}

}

登录界面:

namespace tong_xun_lu_guan_li

{

public partial class Form1 : Form

{

public Form1()

{

InitializeComponent();

}

{

}

private void button1_Click(object sender, EventArgs e)

{

Register reg = new Register();

reg.Show();

this.Hide();

}

private void button2_Click(object sender, EventArgs e)

{

if (textBox1.Text == "" || textBox2.Text == "")

{

MessageBox.Show("用户名和密码不能为空");

}

else

{

DBClass.conn.Open();

DataSet dsMydataBase = new DataSet();

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "select [UsersName] from [Users] where [UsersName] ='" + textBox1.Text + "'";

cmd.ExecuteNonQuery();

if (cmd .ExecuteScalar() == null )

{

MessageBox.Show("用户名不存在!");

textBox1.Clear();

textBox2.Clear();

DBClass.conn.Close();

return;

}

else

{

https://www.360docs.net/doc/e618132256.html,mandText = "select [Userspwd] from [Users] where [UsersName] ='" + textBox1.Text + "'";

cmd.ExecuteNonQuery();

if (textBox2.Text != cmd.ExecuteScalar().ToString())

{

MessageBox.Show("密码错误");

textBox1.Clear();

textBox2.Clear();

DBClass.conn.Close();

}

else if (textBox2.Text == cmd.ExecuteScalar().ToString())

{

MessageBox.Show(" 登录成功!");

Home ho = new Home();

ho.Show();

this.Hide();

}

else

{

Application.Exit();

}

}

}

}

private void textBox2_TextChanged(object sender, EventArgs e)

{

textBox2.PasswordChar='*';

}

private void button3_Click(object sender, EventArgs e)

{

Application.Exit();

}

}

}

注册界面:

namespace tong_xun_lu_guan_li

{

public partial class Register : Form

{

public Register()

{

InitializeComponent();

}

private void Register_Load(object sender, EventArgs e)

{

}

private void button1_Click(object sender, EventArgs e)

{

try

{

if (textBox1.Text == "" || textBox2.Text == "")

{

MessageBox.Show("用户名和密码不能为空");

}

else

{

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "Insert into Users(UsersName,Userspwd) Values('" + textBox1.Text + "','" + textBox2.Text + "')";

cmd.ExecuteNonQuery();

DBClass.conn.Close();

MessageBox.Show("成功注册!");

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select [UsersName] From Users", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView1.DataSource = dsMyDataBase.Tables["BaseInform"];

textBox1.Clear();

textBox2.Clear();

}

}

catch (Exception ex)

{

MessageBox.Show(ex.Message.ToString() + "打开数据库失败!");

DBClass.conn.Close();

}

}

private void button2_Click(object sender, EventArgs e)

{

Form1L = new Form1();

L.Show();

this.Hide();

}

}

}

主界面:

namespace tong_xun_lu_guan_li

{

public partial class Home : Form

{

public Home()

{

InitializeComponent();

}

protected override void OnClosing(CancelEventArgs e)

{

Application.Exit();

}

{

}

private void button1_Click(object sender, EventArgs e)

{

try

{

DBClass.conn.Open();

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * from Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView1.DataSource = dsMyDataBase.Tables["BaseInform"];

DBClass.conn.Close();

}

catch (Exception ex)

{

MessageBox.Show(ex.Message.ToString() + "打开数据库失败!");

DBClass.conn.Close();

}

}

private void button2_Click(object sender, EventArgs e)

{

Form1 L = new Form1();

L.Show();

this.Hide();

}

private void button3_Click(object sender, EventArgs e)

{

if (textBox1.Text == "")

{

MessageBox.Show("请输入要添加的姓名!");

textBox1.Clear();

textBox4.Clear();

textBox7.Clear();

textBox8.Clear();

}

else if (textBox1.Text != "")

{

DBClass.conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "Insert into Contact(姓名,性别,生日,电话,邮箱,地址) Values('" + textBox1.Text + "','" + comboBox1.Text + "','" + dateTimePicker1.Text + "','" + textBox4.Text + "','" + textBox7.Text + "','" + textBox8.Text + "')";

cmd.ExecuteNonQuery();

MessageBox.Show("添加成功!");

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * From Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView3.DataSource = dsMyDataBase.Tables["BaseInform"];

}

}

private void button4_Click(object sender, EventArgs e)

{

this.Close();

}

private void button7_Click(object sender, EventArgs e)

{

if (textBox6.Text == "")

{

MessageBox.Show("请输入要删除的姓名!");

}

else if (textBox6.Text != "")

{

DBClass.conn.Open();

DataSet dsMydataBase = new DataSet();

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "select [姓名] from [Contact] where [姓名] ='" + textBox6.Text + "'";

cmd.ExecuteNonQuery();

if (cmd.ExecuteScalar() == null)

{

MessageBox.Show("用户名不存在!");

textBox6.Clear();

DBClass.conn.Close();

return;

}

else

{

https://www.360docs.net/doc/e618132256.html,mandText = "delete from Contact where[姓名]= '" + textBox6.Text + "'";

cmd.ExecuteNonQuery();

DBClass.conn.Close();

MessageBox.Show("删除成功");

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * From Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView4.DataSource = dsMyDataBase.Tables["BaseInform"];

textBox6.Clear();

}

}

private void button8_Click(object sender, EventArgs e)

{

this.Close();

}

private void button9_Click(object sender, EventArgs e)

{

if (textBox9.Text == "")

{

MessageBox.Show("请输入要修改的姓名!");

textBox9.Clear();

textBox12.Clear();

textBox13.Clear();

textBox14.Clear();

}

else if (textBox9.Text != "")

{

DBClass.conn.Open();

DataSet dsMydataBase = new DataSet();

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "select [姓名] from [Contact] where [姓名] ='" + textBox9.Text + "'";

cmd.ExecuteNonQuery();

if (cmd.ExecuteScalar() == null)

{

MessageBox.Show("用户名不存在!");

textBox9.Clear();

textBox12.Clear();

textBox13.Clear();

textBox14.Clear();

DBClass.conn.Close();

return;

}

else

{

https://www.360docs.net/doc/e618132256.html,mandText = "update Contact set 姓名='"+ textBox9.Text + "',"+ "性别='"+ comboBox2.Text + "',"+ "生日='"+ dateTimePicker2.Text + "',"+ "电话='"+ textBox12.Text + "',"+ "邮箱='"+ textBox13.Text + "'," + "地址='" + textBox14.Text + "'where 姓名='" + textBox9.Text + "'";

cmd.ExecuteNonQuery();

DBClass.conn.Close();

MessageBox.Show("修改成功!");

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * From Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

textBox12.Clear();

textBox13.Clear();

textBox14.Clear();

}

}

}

private void button5_Click(object sender, EventArgs e)

{

try

{

if (textBox5.Text == "")

{

MessageBox.Show("查找的姓名不能为空!");

}

else if (textBox5.Text != "")

{

DBClass.conn.Open();

DataSet dsMydataBase = new DataSet();

SqlCommand cmd = new SqlCommand();

cmd.Connection = DBClass.conn;

https://www.360docs.net/doc/e618132256.html,mandText = "select [姓名] from [Contact] where [姓名] ='" + textBox5.Text + "'";

cmd.ExecuteNonQuery();

if (cmd.ExecuteScalar() == null)

{

MessageBox.Show("用户名不存在!");

textBox5.Clear();

DBClass.conn.Close();

return;

}

else

{

string searchString = "select * from Contact where 姓名='" + textBox5.Text + "'";

SqlDataAdapter dataSelect = new SqlDataAdapter(searchString, DBClass.conn);

DataTable dt = new DataTable();

dataSelect.Fill(dt);

dataGridView2.DataSource = dt.DefaultView;

this.dataGridView2.RowHeadersVisible = true;

DBClass.conn.Close();

textBox5.Clear();

}

} }

catch (Exception ex)

{

}

}

private void button6_Click(object sender, EventArgs e)

{

Application.Exit();

}

private void button10_Click(object sender, EventArgs e)

{

Application.Exit();

}

private void button11_Click_1(object sender, EventArgs e)

{

Application.Exit(); }

private void button13_Click(object sender, EventArgs e)

{

try

{

DBClass.conn.Open();

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * from Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView3.DataSource = dsMyDataBase.Tables["BaseInform"];

DBClass.conn.Close();

}

catch (Exception ex)

{

MessageBox.Show(ex.Message.ToString() + "打开数据库失败!");

DBClass.conn.Close();

}

}

private void button12_Click(object sender, EventArgs e)

{

try

{

DBClass.conn.Open();

DataSet dsMyDataBase = new DataSet();

SqlDataAdapter daBaseInform = new SqlDataAdapter("Select * from Contact", DBClass.conn);

daBaseInform.Fill(dsMyDataBase, "BaseInform");

dataGridView2.DataSource = dsMyDataBase.Tables["BaseInform"];

DBClass.conn.Close();

}

catch (Exception ex)

{

C程序课程设计报告 --手机通讯录管理系统 姓名:谢骏 学院:珠宝学院 学号:649 班级:141082

一课程设计目的和内容概述 1.目的:加深对《C语言》课程所学知识的理解,进一步巩固C语言编程方法。学会编制结构清晰、风格良好、数据结构适当的C语言程序,从而具备解决综合性实际问题的能力,加强动手能力。 2.内容:设计一个简易的手机通讯录管理系统。该题目要求在熟练掌握C语言的基本知识:数据类型(整形、实型、字符型、指针、数组、结构等);运算类型(算术运算、逻辑运算、自增自减运算、赋值运算等);程序结构(顺序结构、判断选择结构、循环结构);大程序的功能分解方法(即函数的使用)等。进一步掌握各种函数的应用,包括时间函数、、绘图函数,以及文件的读写操作等。 其中结构体,函数的调用,算法的设计是尤为重要的。 二题目 手机通讯录管理系统。 [问题描述] 该系统模拟手机通讯录管理系统,实现对手机中的通讯录进行管理 [基本要求] 要能提供以下几种功能: (1)查看功能:选择此功能时,列出下列三类选择:

A:办公类B:个人类C:商务类 (2)当选中某类时,显示出此类所有数据中的姓名和电话号码 (3)添加数据功能:能录入新数据,每个结点包括:姓名,电话号码,分类(可能选项有:w为办公类p为个人类b为商务类),电子邮件。例如:杨春商务类 当录入重复的姓名和电话号码时,则提示数据录入重复并取消录入;当通讯录中超过15条信息时,存储空间已满,不能再录入新数据;录入的新数据能按递增的顺序自动进行条目编号。(4)修改功能:选中某个人的姓名时,可对此人的相应数据进行修改。 (5)删除功能:选中某个人的姓名时,可对此人的相应数据进行删除,并自动调整后续条目的编号。 三程序设计 1.总体设计 首先,因为每个个体有多种信息,所以要建立结构体来储存和整合各个信息。然后利用模块来分别实现程序的各个功能。各个模块用函数来实现。在通过通过主函数来判断输入字母,从而调动函数,实现所需功能。最后将输入的文件保存在文件里,以便重复使用。 2.详细设计

通讯录管理系统课程设 计报告 HEN system office room 【HEN16H-HENS2AHENS8Q8-HENH1688】

设计课题题目 一、课程设计目的与要求 1.课程设计目的 (1)综合运用之前所学知识(选择控制,循环控制,数组,函数,指针,结构体和文件等)来完成一个简单的信息管理程序的设计。 (2)充分体现和体会函数在程序设计中的必要性和实用性,并反映主函数main ()在程序设计中的实现思路和方法。 2. 课程设计要求 制作一个通讯录系统。 (1)该程序具有查找、添加、修改、删除功能。 (2)通讯录包括:姓名、电话、街道、城市、省、邮编等。 二、总体设计 根据系统的要求,系统总体设计如图1所示。 1

printf("\t--------------------\n"); printf("\t请您选择(0-7):"); scanf("%d",&c); }while(c>7&&c<0); return(c); } int Input(struct date per[10],int n) { int i=0; char sign,x[10]; while(sign!='n'&&sign!='N') { printf("\t姓名:"); scanf("%s",per[n+i].name); printf("\t电话号码:"); scanf("%s",per[n+i].phone); printf("\t电子邮箱:"); scanf("%s",per[n+i].email); printf("\tQQ:"); scanf("%s",per[n+i].QQ); gets(x); printf("\n\t是否继续添加?(Y/N)"); fflush(stdin); ame,per[i-1].phone,per[i-1].QQ,per[i-1].email); if(i>1&&i%10==0) { printf("\t-----------------------------------\n"); printf("\t"); system("pause"); printf("\t-----------------------------------\n"); } } printf("----------------------------------------------------------------------\n"); system("pause"); } int Delete_a_record(struct date per[10],int n) { char s[20]; int i=0,j; printf("\t请输入想删除记录中的名字:"); scanf("%s",s); while(strcmp(per[i].name,s)!=0&&i

二〇〇八~ 二〇〇九学年第二学期 信息科学与工程学院课程设计报告书 课程名称:C语言课程设计 班级: 学号: 姓名:薛其乐 指导老师:

二〇〇九年九月 通讯录管理系统 一.需求分析 设计题目及要求: ◆建立通讯录信息,信息至少包含编号、姓名、年龄、电话、通讯地址、电子 邮箱等; ◆能够提供添加、删除和修改通讯录信息的功能; ◆能够提供安不同方式查询的功能;如按姓名或年龄、电话等查询; ◆将通讯录保存在文件中; ◆能够按表格方式输出通讯录信息。 系统功能需求分析: 主要包含一下多种功能: 添加:添加通讯录记录 显示:显示通讯录记录 删除:删除通讯录记录 查询:查询通讯录记录 修改:修改通讯录记录 保存:将信息保存到文件 二.概要设计 系统功能模块图:

添加:可以添加通讯录记录,依次输入编号、姓名、年龄、电话号码、通讯地址、电子邮箱后,会提示是否继续添加。 显示:可以以表格形式输出所有通讯录里的记录 删除:输入欲删除的那个人的名字后,会自动删除他(她)的记录内容 查询:可以选择用姓名、电话、地址三种方式查询 修改:输入欲修改的那个人的名字后,再依次输入编号、姓名、年龄、电话号码、通讯地址、电子邮箱即可完成修改 保存:,输入文件名(带后缀名)后,即可将通讯录信息保存到文件 三.详细设计 (1).通讯录: typedef struct { char score; /*编号*/ char name[10]; /*姓名*/ char num[15]; /*号码*/ char email[20]; /*邮箱*/

char age[8]; /*年龄*/ char adds[20]; /*住址*/ }Person; void main() /*主函数*/ { int n=0; for(;;) { switch(menu_select()) { case 1: printf("\n\t添加记录到通讯录\n"); /*添加记录*/ n=Input(pe,n); break; case 2: printf("\n\t\t\t 通讯录记录表\n"); /*显示记录*/ Display(pe,n); break; case 3: printf("\n\t从通讯录中删除记录\n");

C课程设计通讯录管理 系统 文件排版存档编号:[UYTR-OUPT28-KBNTL98-UYNN208]

课程设计说明书(论文)课程名称 C++程序设计实践 题目通信录管理系统 专业软件工程班级 学号姓名 xx 起止日期 指导教师赵新慧成绩 辽宁石油化工大学计算机与通信工程学院

摘要 本次课程设计任务是通过编写一个通信录管理系统,学习用Visual?C++?开发简单的管理系统。采用Visual?C++?软件为主要开发工具。巩固和加深学生对C++课程的基本知识的理解和掌握,掌握C++编程和程序调试的基本技能,利用C++进行简单软件设计的基本思路和方法,提高运用C++解决实际问题的能力,掌握书写程序设计说明文档的能力使用计算机进行信息管理。实现通信录的管理功能(添加、删除、排序)、按姓名查询的功能,以及把联系人资料保存在文件中,将文件中内容读出来。使用计算机进行系统管理,不仅提高了工作效率,而且大大提高了其安全性,尤其对于复杂的信息管理,计算机能充分地发挥它的优越性,通信录管理系统是每个人不可缺少的部分,在课程设计中,系统开发平台为Windows XP,程序设计语言采用Visual C++,在程序设计中,运用了面向对象解决问题的方法。程序通过调试运行,初步实现了设计目标。 Abstract The curriculum design task is through the preparation of a student achievement ranking management system, learning management system with Visual C++ 6 to develop simple. Using Visual C++ 6 software as the main development tool. To consolidate and deepen the students the basic knowledge of C++

3.6 实例6 通讯录程序 本实例希望设计一个通讯录程序,要求实现通讯录信息的录入,并具有添加、查询、删除、显示等功能;使用结构体存储通讯录中记录信息;使用链表来实现通讯录信息的添加、删除、查询及显示等操作;通讯录程序可实现文件读写,在通讯录信息录入结束之后,可存入文件中,在下次程序运行时可将通讯录中的记录读取到程序中。通讯录程序可采用基于Win32控制台程序构建或采用基于MFC应用向导.EXE的应用程序,下面对这两种方法进行详细介绍。 3.6.1. 设计目的 1、掌握结构体的基本工作原理和工作方式。 2、熟悉结构体与链表的使用方法。 3、熟悉C语言下数据的输入与输出。 4、掌握C语言下对TXT文件的读写操作。 5、熟悉函数的设计方法及调用方法。 3.6.2. 基本要求 1、本实例要求实现对通讯录信息的查找、添加、删除、显示等功能,每个功能模块均能实现随时从模块中退出,可以通过键盘对功能进行选择,完成一个通讯录管理系统的运行。

2、要使用结构体来实现对通讯录信息的存储。 3、使用链表来实现对通讯录信息的查找、添加、删除、浏览显示。 4、使用文件对记录进行存储,程序运行时还可以从文件中读取记录。 5、系统设计完成后应实现类似下图所示界面。 3.6.3 设计结构及算法分析 在进行程序设计时,选择一种合理的数据存储结构是非常关键的。本实例根据题目要求,采用结构体来存放通讯录中的信息,并采用文件存储通讯录中的信息。 1、存储结构 本实例存储数据时,除了采用最常用的基本类型存储外,采用结构体的方式来存储通讯录中的个人信息,结构体如下所

示: struct stu { char name[20]; /*人名*/ char telephone[20]; /*电话*/ char sex[4]; /*性别*/ char company[20]; /*单位*/ struct stu *next; /*链表节点*/ }; typedef struct stu STU; 2、main()主函数 采用模块化设计,功能放在各模块函数中实现。主函数是程序的入口,在其中采用循环结构,根据用户的键盘输入,依次调用各功能函数。 3、mycreate()函数------创建链表函数 函数根据用户输入的信息,存储到结构体中,并建立链表结构,函数返回链表的头指针。链表建立完成后,可根据链表的头指针来添加后续指针。 4、myadd()函数------添加学生信息记录函数 函数根据用户输入信息,分配内存,将数据存储到结构体中,并建立新的链表节点,链接到已经建立好的链表尾部。 5、mydelete()函数------删除链表节点

JIANGXI AGRICULTURAL UNIVERSITY JA V A课程设计报告 题目:通讯录系统 二0一二年十二月 摘要 随着Internet速度的提高和使用的普及,网络上各式各样的应用层出不穷,通讯录系统就是其中的一种。在现实生活中,我们管理通讯录有多种方式,为了进一步提高管理通讯录的效率以及及时更新通讯录,特开发通讯录系统来方便用户使用和管理通讯录。 本系统采用Ecilpse编写程序,具有良好的程序结构和人机交互界面,通用性强。本文将从开发技术、需求分析、系统设计、编码实现和设计总结这几个方面,详细介绍

通讯录系统的设计和实现过程。 关键词:通讯录系统;JA V A;Eclipse;需求分析。

目录 1 绪论 (2) 1.1 概述 (2) 2 开发技术与工具选择 (2) 2.1 Eclipse介绍 (2) 2.1.1 Eclipse的基本概念 (2) 2.1.2 Eclipse 插件开发环境 (2) 2.1.3 Eclipse的主要组成 (2) 3 需求分析 (3) 3.1 概要说明 (3) 3.2 产品描述 (3) 3.3 系统功能列表 (3) 3.4 系统功能说明 (3) 3.4.1 <添加模块> (3) 3.4.2 <查询模块> (3) 3.4.3 <修改模块> (4) 3.4.4 <删除模块> (4) 3.5系统质量需求 (4) 4 系统设计 (4) 4.1说明 (4) 4.2总体设计结构图 (4) 4.3 总用例图 (5) 4.4 流程图 (5) 5 编码与实现 (8) 5.1包结构图 (8) 5.2主界面 (9) 5.3组操作的页面 (9) 5.4 好友操作界面 (10) 6 项目设计总结 (11) 6.1系统概述 (11) 6.2关键问题的分析和解决 (11) 6.3 系统展望 (11) 6.4 自身收获 (11) 致谢 (12) 参考文献 (13)

通讯录管理系统 要求: 1.创建文本文件,记录联系人的信息。 2.以菜单方式工作 3.联系人的信息包括:姓名,籍贯,电话号码,QQ号等信息 4.管理系统的功能包括: a)增加:添加新的联系人 b)删除:删除一个联系人(输入电话号码,删除该联系人) c)修改:修改某个联系人的信息 i.修改姓名 ii.修改电话号码 iii.修改籍贯 iv.修改QQ号 d)查询 i.根据名字查询联系人信息(查询结果不唯一) ii.根据电话号码查询联系人信息 iii.根据QQ号查询联系人信息 实现过程分析: 建立一个文本文件,记录联系人的基本信息 建立以下几个类: 1.联系人类:表示一个联系人 数据成员包括: 姓名 籍贯 电话号码 QQ号 成员函数包括 一组set函数为数据成员赋值 一组modify函数,修改数据成员的值 Display函数:显示联系人的信息 2.通讯簿类(这是一个数据库类):用于记录所有联系人的信息 数据成员包括: 联系人的数量 联系人对象数组 成员函数包括 构造函数:读取文本文件中的数据,并根据文件内容创建联系人对象数组 析构函数:将对象数组中的内容写入到文本文件中。 增加函数:增加一个联系人 删除操作:删除一个联系人 Display:显示所有联系人的信息 修改某一联系人的信息: 查询并显示某一联系人的信息:

3.用户类(这是一个操作类,完成通讯簿的操作):用户拥有一个通讯簿,并且可以对通讯录进行管理 数据成员包括: 通讯簿对象 成员函数包括(成员函数体现用户的行为): 添加联系人:调用通讯簿对象的增加函数完成联系人的添加 删除联系人:调用通讯簿对象的删除操作删除一个联系人 Display:显示所有联系人的信息 修改某一联系人的信息:调用通讯簿对象的函数完成操作 查询并显示某一联系人的信息:调用通讯簿对象的函数完成操作4.界面菜单类:用来给出操作提示 数据成员:可以不定义数据成员 成员函数: Display函数:显示操作菜单的提示。说明:可以根据需要定义多个函数,显示不同的菜单(操作提示)。 #include #include #include #include class person { int tel; int QQ; char name[20]; char nplace[40]; public: int set_tel() { return tel; } int set_QQ() {

大学 课程设计说明书 课程名称管理信息系统题目通讯录管理系统 学院 班级

学生姓名 指导教师 日期 目录 1.需求分析 (3) 2.系统分析 (4) 2.1.系统的可行性研究 (4) 2.2.功能需求分析 (4) 3.系统设计 (5) 3.1.系统模块设计 (5) 3.2.数据库设计 (5) 4.系统实施 (7) 4.1.开发环境 (7) 4.2.建立数据库 (7) 4.2.1.数据库创建代码 (7) 4.2.2.数据库表创建代码 (8) 4.3.程序设计 (10) 4.3.1.主程序的设计 (10) 4.3.2.登录界面的设计 (12) 4.4.系统测试 (19) 5.课程设计总结 (25)

6.参考文献 (26) 1.需求分析 随着社会的发展,人际关系变得越来越重要,为了保持良好的人际关系,必须

经常与亲戚、朋友、同学、同事保持联系,但是有时候存在着许多的限制条件,比如怎样找到交流对象的各种信息?可能你会想到现实生活中的手机等通讯工具,由于这些工具的单一性,不可能在第一时间找到自己想要的信息资料,因此,为了能够快速查找到联系人的信息,节省查找时间,开发通讯录管理系统。 通讯录管理系统是一个基于SQL数据库储存和JAVA界面模式的个人通讯录管理系统。它是将自己的联系人的具体信息集中管理,成为一个方便人们使用的小软件。在开发过程中主要运用Java, SQL Server技术,由于开发工具和数据库之间的良好使用,可以为开发带来方便,使之成为一个可施行的系统。从而达到开发的目的-----实现对通讯录信息的管理。 通过采用相关技术,以及老师的辅导和同学们的帮助,将系统设计的功能全部实现。功能包括:用户的登录, 添加联系人信息,修改联系人信息,删除联系人信息,查询联系人信息,可以浏览全部通讯的联系人,并且可以根据数据表的各字段来查询你所要找的联系人等功能。 2.系统分析 2.1. 系统的可行性研究 目的:可行性研究的目的是用最小的代价在尽可能少的时间内确定问题是否能够解决。而该系统正式用比较简单的VFP语言来编写的小型的、实用的通讯录信息管理系统,既能很好地完成对用户信息的管理,又比较经济实惠。本系统采用的是VFP语言,在技术难度方面,由于有指导老师的指导和相关参考文献,特别是网上也有很丰富的相关资料,通过参考一些功能模块程序的设计,实现该系统是完全可以的。 本系统的设计是在windows XP中文版环境下,使用Visual开发的。它是可以运行于windows XP相关平台的数据库开发系统。Visual不仅可以简化数据库管理,而且应用程序的开发流程更为合理,它使组织数据,定义数据库规则和建立应用程序的工作变得简单易行,利用可视化的设计工具和向导,用户可以快速的创建表单、查询等。 2.2. 功能需求分析 本系统主要实现对通讯录信息进行管理,需要实现以下几个方面的管理功能: (1)通讯录管理信息:信息的添加、删除、浏览、修改和查询等操作。 (2)系统维护:包括用户登录,用户修改密码,数据的修改、浏览、添加、删除以及按姓名、联系方式、地址进行查询。

开放教育 课程设计报告书 课程名称:通讯录管理系统 班级:综合邮政07秋 学号: 0 姓名:王芬 指导老师:高海东

通讯录管理系统 一.需求分析 设计题目及要求: ◆建立通讯录信息,信息至少包含编号、姓名、年龄、电话、通讯地址、电子 邮箱等; ◆能够提供添加、删除和修改通讯录信息的功能; ◆能够提供安不同方式查询的功能;如按姓名或年龄、电话等查询; ◆将通讯录保存在文件中; ◆能够按表格方式输出通讯录信息。 系统功能需求分析: 主要包含一下多种功能: 添加:添加通讯录记录 显示:显示通讯录记录 删除:删除通讯录记录 查询:查询通讯录记录 修改:修改通讯录记录 保存:将信息保存到文件 二.概要设计 系统功能模块图:

添加:可以添加通讯录记录,依次输入编号、姓名、年龄、电话号码、通讯地址、电子邮箱后,会提示是否继续添加。 显示:可以以表格形式输出所有通讯录里的记录 删除:输入欲删除的那个人的名字后,会自动删除他(她)的记录内容 查询:可以选择用姓名、电话、地址三种方式查询 修改:输入欲修改的那个人的名字后,再依次输入编号、姓名、年龄、电话号码、通讯地址、电子邮箱即可完成修改 保存:,输入文件名(带后缀名)后,即可将通讯录信息保存到文件 三.详细设计 (1).通讯录: typedef struct { char score; /*编号*/ char name[10]; /*姓名*/ char num[15]; /*号码*/ char email[20]; /*邮箱*/ char age[8]; /*年龄*/ char adds[20]; /*住址*/ }Person;

数据结构课程设计报告 专业:计算机科学与技术 年级: 课题名称:通讯录 小组成员1: 小组成员2: 小组成员3: 信息技术学院专业教研室一 一、问题描述

设计目的:用〈〈数据结构〉〉中的双向链表作数据结构,结合C语言基本知识。编写一个通讯录管理系统。以把所学数据结构知识应用到实际软件开发中去。 设计内容:本系统应完成一下几方面的功能: 1) 输入信息——enter(); 2) 显示信息———display( ); 3) 查找以姓名作为关键字———search( ); 4) 删除信息———delete( ); 5) 存盘———save ( ); 6) 装入———load( ) ; 设计要求: 1) 每条信息至包含:姓名(NAME )街道(STREET)城市(CITY)邮编(EIP)国家(STATE)几项 2) 作为一个完整的系统,应具有友好的界面和较强的容错能力 3) 上机能正常运行,并写出课程设计报告 二、需求分析 A,添加: 系统将提示用户输入新添加人员信息,输入到文件中,人员信息数据包括姓名(name),街道(street),城市(city),邮编(eip),国家(state). B,删除: 首先由用户输入要删除的人员的姓名,然后调用删除函数,删除该人员的所有相关资料. C,显示所有人员信息: 该功能将显示已经保存的所有人员的姓名,街道,城市,邮编及国家. D,查询: 可由用户输入要查找的人员姓名,然后系统用查找函数查找,接着系统使用相关文件命令输出所查找的人员的全部信息. E,退出系统 关闭通讯录管理系统. 三、概要设计 六个函数的实现: void enter(); 新添纪录

C++面向对象程序设计 课程设计报告 》 设计题目:通讯录系统 学生学号: P P 学生姓名: 王元波次仁多布杰 专业班级:2009级计算机科学与技术(3)班学生成绩: 指导教师:蔡正琦 ] 计算机科学与信息工程学院 2010-6-26

一、设计任务分析 实现以下功能: · 1) 通讯录编辑(添加、删除); 2) 按不同的项进行查找; 3) 对已存在的通讯录按不同的项排序; 4) 将通讯录写入文件; 5) 从文件读入通讯录。 二、模块设计 本次程序设计主要设计了六个模块(主要是:(),(),(),(),(),(),())()函数用于通讯录中的信息进行添加,主要流程如下: — ()函数用于通讯录中的信息进行删除,主要流程如下:

()函数用于通讯录中的信息进行修改,主要流程如下: ()函数用于通讯录中的信息进行查找,主要流程如下:

~ ()函数用于通讯录中的信息进行排序,主要流程如下: ()函数用于从文本文件中读取信息,主要流程如下:

()函数用于将信息写入文本文件,主要流程如下:

三、… 四、主要数据结构 结构数组: struct student o<

攀枝花学院课程设计 题目:通讯录 院(系):数学与计算机学院 年级专业: 12网络工程 姓名:杨莎 学号: 201210803040 指导教师:何全庆 二〇一三年十二月三十日 攀枝花学院教务处制

攀枝花学院本科学生课程设计任务书 注:任务书由指导教师填写。

摘要 通讯工具在平常百姓家中已经是非常常见。用Java语言开发这个强大通讯录以实现我们对大量的人员的通信信息予以记录。以便我们使用方便。我们可以往这个通信录系统中添加数据,也可以对记录进行修改,删除。这样大大提高了我们的通信管理效率。 随着人们生活水平的提高,通讯工具在平常百姓家中已经是非常常见。要记 住所有的联系方式似乎有些困难,所以我们希望设计一个通讯录系统,记录所有 的联系方式,并且能方便的查找,增加和删除,方便大家记录联系人。 当前计算机软件技术和网络技术正飞速发展,软件系统日趋大型化、复杂化, 软件对于一个计算机系统是至关重要的。因此社会对软件开发者提出了比以往更 高的要求,相应的系统要求也有了很大的提高。本系统用C++作为程序语言,设 计出的系统功能强大,操作方便灵活。 关键词:通讯录;java; 数据;查询; -Ⅰ-

目录 摘要 (Ⅰ) 1需求分析 (6) 1.1需求来源 (6) 1.2设计目的 (6) 1.3设计要求 (6) 2 功能需求描述 (6) 3 总体设计 (6) 3.1 功能介绍 (7) 3.2 系统模块结构 (7) 3.3 系统总设计流程图 (7) 4 概要设计 (8) 4.1登录功能界面 (8) 4.2添加功能界面 (9) 4.3删除功能界面 (9) 4.4查询功能界面 (10) 4.5统计功能界面 (10) 5程序与分析 (11) 5.1登陆系统 (11) 5.2增加纪录 (13) 5.3 删除记录 (14) 5.4修改记录 (15) 5.5查找记录 (17) 致谢 (18) 参考文献 (19)

合肥学院 计算机科学与技术系 课程设计报告 2013~2014学年第二学期 课程面向对象课程设计 课程设计名称通讯录程序 学生姓名XXX 学号 专业班级XXXXX 指导教师XXX 20 年月

目录 一、设计题目 (1) 二、设计要求 (1) 三、总体设计 (1) 3.1系统功能框架 (1) 3.2系统功能说明 (3) 四、详细设计 (3) 1.数据结构设计 (3) 2.系统模块设计 (10) 五、运行结果 (13) 一.设计题目 随着社会的进步与发展,通讯越来越密切。希望能通过对java课程设计的学习和掌握来编写一个通讯录管理系统。 二.设计要求 (1)只能使用Java语言,采用面向对象方法进行设计,要求源程序要有适当的注释,使程序容易阅读。 (2)程序必须与数据库进行通信。

(3)系统必须是图形用户界面的形式并连接数据库 三. 总体设计 3.1 3.2 系统功能说明 (1)具有新用户注册功能。 (2)具有注册用户登录功能。 (3)具有数据的录入功能。 (4)具有数据查询功能,可以实现查询全部信息和按条件执行查询。(5)具有按条件删除数据功能。

(6)具有统计功能 4. 详细设计 4.1数据结构设计(java程序设计) //登录系统 package com.ibm.etp.addressbook.action; import java.util.HashMap; import java.util.List; import https://www.360docs.net/doc/e618132256.html,er; import com.ibm.etp.addressbook.service.LoginService; import com.opensymphony.xwork2.ActionSupport; public class LoginAction extends ActionSupport { private static final long serialVersionUID = 1L; public String username; public String password; private String message; @Override public String execute() throws Exception { HashMap result = new HashMap(); List list = null; System.out.println(username); if(username == null || username.trim().length() == 0) { result.put("success", false); result.put("msg", "https://www.360docs.net/doc/e618132256.html,ername.empty"); } else if(password == null || password.trim().length() == 0) { result.put("success", false); result.put("msg", "login.password.empty"); } else { LoginService ls = new LoginService(); list = ls.checkLogin(username); } if(list == null) { result.put("success", false); result.put("msg", "https://www.360docs.net/doc/e618132256.html,er.not.exist"); } else if(list.get(0).getPassword().equals(password)) { result.put("success", true); result.put("msg", "login.success"); } else {

通讯录系统的设计与实现桂林电子科技大学电信三班傅得耕 3.1系统的需求分析 通讯录系统作为一个应用软件将为人民提供一个可以串联人与人之间的信息的一个平台。根据系统界面的提示信息对通讯录进行查询、初始化等操作。 系统功能需求分析描述如下: (1)创建联系人。 (2)显示所有联系人:显示可以进行的操作。 (3)删除联系人。 (4)查询:根据姓名进行查询,并可显示所有关于该人的信息。 (5) :退出。 3.2系统的设计 3.2.1 系统的总体设计 下面从系统的整体流程的功能模块、系统界面及数据结构进行总体设计。 (1)总体思想 本系统主要设计思想是实现通讯录系统信息的创建联系人、删除、查找等主要功能。系统的设计方法是结构化实际方法,系统用C语言进行开发用户可以清晰的了解联系人的情况。 (2)系统模块结构图 根据需求分析结果,通讯录系统可以分为五大模块:创建联系人模块、显示功能模块、查找联系人功能模块、删除联系人模

块以及退出模块。 ㈡查询人物信息 进入此菜单功能模块,输入您要查询的图书的名字。 图书查询模块流程如图: 3.3 创建

删除系统 3.4 源代码 #include #include #include #define LEN sizeof(struct people) struct people { char name[10]; char address[50]; char postcode[7]; char phonenum[12]; struct people * next; }; int n = 0, c; static struct people * head; void insert(); void show();

c语言课程设计学生通讯 录管理系统 Last revision date: 13 December 2020.

题目:学生通讯录管理系统 任务说明: 主要利用c语言的文件操作能力设计开发一个小型的通讯录管理系统,至少具有如下功能: ①记录通讯录内的人员的学号、姓名、地址、电话号码。 ②显示所有人员的信息。 ③通过输入姓名查找人员信息。 ④通过输入姓名查找到要删除的人员信息,然后可以进行删除。 ⑤通过输入姓名查找到要修改的人员信息,然后可以进行修改。 ⑥添加人员信息。 系统功能描述: 本程序的功能是为用户提供简单的通讯录进行管理,通过该程序存储联系人信息,提供关键字(只能是英文关键字进行查找)查找功能,可以对数据进行修改、删除、添加等操作。 各按钮的功能如下: 查找记录:以姓名为关键字,查找并显示该记录。若查找不到,则显示“好象没有”;

添加记录:将当前记录按姓名序加入通讯录,然后显示第一条记录; 修改记录:修改当前记录,显示当前记录。姓名为关键字,不允许修改; 删除记录:删除当前记录,然后显示第一条记录; 第一条记录:将当前记录指针移动至首节点,若已为首节点,则不移动; 前一条记录:将当前记录指针向前移动一个节点,若已为首节点,则不移动; 后一条记录:将当前记录指针向后移动一个节点,若已为尾节点,则不移动; 最后一条记录:将当前记录指针移动至尾节点,若已为尾节点,则不移动; 加载:从文件中掉入已保存的通讯录数据; 保存:保存通讯录数据; 退出:退出系统;

设计思路: 根据要求,电话录数据以文本文件存放在文件中,故需要提供文件的输入、输出等操作;还需要保存记录以进行修改,删除,查找等操作;另外还应提供键盘式选择菜单实现功能选择。 图1 系统功能模块图 软件中使用的结构体和结构体数组,如: struct callmember { char name[20]; char address[20]; char code[20]; char callnumber[20]; }; 对用户的信息进行保存,他们都以二进制的形式读写。 其中: char name[20];

课程名称: 程序设计基础课程设计 学院名称: 计算机科学与工程学院 专 业: 计算机科学与技术 课程设计报告 装 订 线

目录 一、绪论 (3) 二、设计内容 (4) 1、选题 (4) 2、系统功能 (4) 3、应用到的技术 (4) 三、设计要求 (4) 四、设计环境 (5) 1、操作系统 (5) 2、开发工具 (5) 3、PC机配置 (5) 五、系统结构图 (5) 六、功能实现 (6) 1、系统运行 (6) 2、添加联系人 (6) 3、修改联系人 (7) 4、删除联系人 (8) 5、查找联系人 (8) 6、查看所有联系人 (8) 7、对联系人在文件中的存储位置进行排序 (9) 8、系统运行结束 (9) 七、遇到的问题和解决的方法 (9) 八、设计心得 (10) 九、参考文献 (11) 十、附件 (12) 1、头文件 (12) 2、主函数 (12) 3、函数实现文件 (13)

需求分析 在这个信息化的时代,手机已成为继固话之后最为通俗的交流工具。在这个人与人关系愈加密切的时代,“通讯”成了生活中的必需品。这就有这么一个系统记录下人与人之间的多样联系方式——手机通讯系统。通过系统记录下对方的联系方式,既减轻了大脑的负担,又不在受各种条件的约束,做到便捷随身管理相关的联系信息,摆脱了传统电话簿,名片的累赘。从长远利益来看,可是意义重大的环保之举。 根据市场需求,手机通讯录管理系统所记录的信息一般分为个人、商业、办公三类。清晰了机主的联系方向。针对性的分门别类,使系统具有了方便了机主的存储和快速查阅优势功能,大大减少了在电话簿,名片上机械翻阅查找过程的时间。于此同时又根据手机随身携带的特殊性,在一定程度上比一般的制作文件又其次,因为手机是随身携带的通讯工具,这与记事本相比将在一定程度上保障联系人信息的安全性,相对避免了个人隐私信息外泄从而带来的损失。 综上所述,手机通讯录管理系统是一个高效、实时、绿色环保的管理系统。 友元重载常函数构造函数析构判断数据链表 手机通讯录管理系统 一、主要功能 模拟手机通信录管理系统,要求: (1)查看功能:选择此功能时,列出下列三类选择: A 办公类 B 个人类 C 商务类,当选中某类时,依次显示出此类所有数据中的姓名和电话号码 (2)增加功能:能录入新数据(包括:姓名、电话号码、分类(可选项有:A 办公类 B 个人类 C 商务类)、电子邮件)。 ?当录入了重复的姓名和电话号码时,提示数据录入重复并取消录入; ?通信录容量限定在15条以内。 ?当存储信息超出存储空间,提示存储空间已满,不能再录入新数据; ?录入的新数据能按递增的顺序自动进行条目编号。 (3)拔号功能:能显示出通信录中所有人的姓名,当选中某个姓名时,屏幕上模拟打字机的效果依次显示出此人的电话号码中的各个数字,并伴随相应的拔号声音。 (4)修改功能:选中某个人的姓名时,可对此人的相应数据进行修改 (5)删除功能:选中某个人的姓名时,可对此人的相应数据进行删除,并自动

课程设计--通讯录管理的设计与实现

课程设计(大作业)报告 课程名称:数据结构课程设 计 设计题目:通讯录管理的设计与实 现 院系:信息技术学院 班级:10级计算机应用技术 班 设计者:李婷 学号:201011020120 指导教师:阿圆 设计时间: 2011-12-26~2011-12-30

信息技术学院 昆明学院课程设计(大作业)任务书 姓名:李婷院(系):信息技术学院 专业:计算机应用技术学号:201011020120 任务起止日期:2011-12-26~2011-12-30 课程设计题目: 通讯录管理的设计与实现 课程设计要求: 1)问题描述 通讯录管理系统一般包括通讯者结点信息的插入、查询、删除、输出功能,通讯者结点的信息一般包括编号、姓名、性别、电话、地址等项。 2) 基本功能 (1)通讯录的建立; (2)通讯者信息的插入;

(3)通讯者信息的查询(按姓名或编号查询); (4)通讯者信息的删除; (5)通讯录信息的输出; 工作计划及安排: 1、问题分析和任务定义;(0.5天) 2、数据类型和结点结构设计;(0.5天) 3、算法设计与分析(1.5天) 4、编码实现和上机调试;(1.5天) 5、总结和整理课程设计报告。(1天) 指导教师签字 2011年12 月29 日

课程设计(大作业)成绩 学号:201011020120 姓名:李婷指导教师:阿圆 课程设计题目: 通讯录管理的设计与实现 总结: 我们经过一个星期的时间把我们的通讯录管理的设计与实现做了出来,时间有些赶,做出来的有点不是很好,我们主要做了菜单模块:显示通讯员信息的菜单,共用户选择所需功能;输出模块:添加删除功能:能根据通讯员人事的变动情况,添加删除记录,利用void Add(Link l)实现添加,利用void Del(Link l)实现删除;显示模块:把通讯员的信息显示出来,通过void Disp(Link l)来实现;查询功能:能根据编号和姓名进行查询通过void Qur(Link l)实现;编辑功能(高级):根据查询对相应的记录进行修改,并存储;保存功能:能对输入的数据进行相应的存储;而我主要的是完成主菜单,添加,删除,显示四个模块和其他的模块的完善,我们分工合作,而另一些部分,我虽然没写,但是组员是在一边写一边跟我讲解每条语句的意思是什么,而我写的时候,

目录 第一章设计分析 (2) 1.1 需求分析 (2) 1.2 功能设计 (2) 第二章概要设计 (3) 2.1 程序设计 (3) 2.2 功能设计 (4) 第三章软件环境介绍 (5) 3. 1 开发环境 (5) 3. 2 开发工具 (5) 3. 3 MySql数据设计 (6) 第四章测试运行 (7) 4.1 程序运行界面 (7) 4.2 新建功能 (7) 4.3 修改功能 (8) 4.4 顺序显示 (8) 4.5 分组显示 (9) 4.6 搜索功能 (9) 第五章总结与分析 (10) 第七章参考文献 (11) 第八章程序源代码 (12) 8.1 类PhoneNumber (12) 8.2 类Operation (15) 8.3 类Searcher (19)

1.1需求分析 现在各大手机都有自己的、各种通讯录程序,但是这些公司都有自己的版权,我们也不可能得到这些源代码!而且这些公司的程序也相当复杂,仅从日常应用方面来说,对于初学java的我们也无法理解,就需要我们开发一个简单易懂的电话号码查询系统程序。 1.2功能设计 本程序的构建参照了手机通讯录,其功能是: 有电话录入,修改,增加,删除,按姓名查询,按电话号码查询,按部门查询,按部门显示,显示所有电话号码信息,打印等功能。

2.1程序设计 在本程序设计过程中用到了父类JFrame、JTable、JPanel、JMenuBar、JMenuItem、JButton。 JMenuBar用来创建主菜单 JMenuItem创建子菜单 JFrame创建框架 JTable创建表格部分 JScorollPane向文本框添加滚动条 JMenuItem创建功能键 JButton添加触发按钮。 编写BufferReader()方法实现待分析文件中数据的读取。 编写readLine()方法实现数据的读取。 编写Select()法实现查询。 编写rankVector()方法实现排序 编写addNumber()方法实现新建 编写removeNumber()方法实现删除 编写modifyPhoneNumber()方法实现修改 利用actionPerformed ()方法做为事件监听器。 编写J_fenxi()实现构造。

安徽工业大学 《C语言课程设计》实习综合报告课题名称:个人通讯录管理系统 实习成员:王刚 学号: 109074372 专业班级: 网络工程103班 指导教师: 郑啸老师

目录 一.问题描述 (2) 二. 各功能流程图与设计思路 (3) 2.1显示模块 (3) 2.2查找模块……………………………………………4.. 2.3添加模块 (6) 2.4删除模块 (8) 2.5修改模块 (9) 三、文件的读取与保存 (11) 四、程序源代码 (12) 五、调试与运行结果 (18) 六、计算机学院课程设计评定意见 (24) 一.问题描述

设计通讯录包含以下功能: (1)通讯录的每一条信息包括姓名、单位、固定电话、移动手 机、分类(如同事、朋友、同学、家人等)、EMAIL、QQ 等。 (2)输入功能:可以一次完成若干条信息的输入。 (3)显示功能:完成全部通讯录信息的显示。 (4)查找功能:可以按姓名等多种方式查找通讯信息。 (5)增加、删除、修改功能:完成通讯录信息的多种更新。 二.各功能流程图与设计思路 Menu菜单:

运用switch()进行操作: case'1': 显示功能,list()函数 说明:利用for循环,逐个输出已保存的内容 代码如下: //*****************显示通讯录中的内容************* void list() { printf("编号姓名电话 \t手机 \t工作单位\tEMAIL \t\tQQ\n"); for(i=0;i

相关文档
最新文档