C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單電子通訊錄(2)
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單電子通訊錄的具體代碼,供大家參考,具體內(nèi)容如下
這兩天學(xué)完系統(tǒng)調(diào)用和標(biāo)準(zhǔn)IO,之前的通訊錄可以進(jìn)行一些改進(jìn),將數(shù)據(jù)保存到文件中(圖我這里就不發(fā)了)。
原理:每次啟動(dòng)程序時(shí)先從預(yù)設(shè)文件中以只讀的形式讀取保存的通訊錄信息,然后將讀取到的信息導(dǎo)入到結(jié)構(gòu)體中;每次執(zhí)行退出時(shí),先將預(yù)設(shè)文件以更新方式打開(kāi),并將文件中之前保存的信息清空,然后將結(jié)構(gòu)體的數(shù)據(jù)保存到文件中去,再退出程序。
還有在文件寫(xiě)入時(shí)和讀取時(shí),先寫(xiě)入(讀?。┍4鏀?shù)據(jù)的總個(gè)數(shù),讓程序知道有多少數(shù)據(jù)要寫(xiě)入(讀?。缓蟊4婷總€(gè)數(shù)據(jù)的字節(jié)數(shù)(程序會(huì)根據(jù)每個(gè)數(shù)據(jù)的字節(jié)數(shù)來(lái)進(jìn)行保存),最后再保存數(shù)據(jù)。
與之前版本相比,改動(dòng)的只有主函數(shù)中加入了讀取文件和寫(xiě)入數(shù)據(jù)這兩個(gè)步驟,還有的變動(dòng)就是結(jié)構(gòu)體從一個(gè)變成了兩個(gè),將指針從原來(lái)一個(gè)結(jié)構(gòu)體中分離出來(lái),方便數(shù)據(jù)從文件中的導(dǎo)入導(dǎo)出。下面是代碼(免得你們往前翻,我把之前的代碼都修改了考過(guò)來(lái)):
頭文件 head.h 唯一修改的就是結(jié)構(gòu)體
#ifndef HEAD_H_
#define HEAD_H_
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h> // sleep函數(shù)頭文件
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#define uint unsigned int
#define OK 0
#define ERROR -1
#define MALLOC_ERROR -2
#define N 20
typedef int ElementType;
typedef struct data
{
ElementType ID; // ID號(hào)
char Name [N]; // 姓名
char Mobile_Phone [N]; // 手機(jī)號(hào)碼
char Home_Address [N]; // 家庭住址
char Company_Tell [N]; // 公司電話
}Data;
typedef struct _Node
{
Data data;
struct _Node* next; // 節(jié)點(diǎn)指針
}Node;
typedef Node* PNode; // 重命名節(jié)點(diǎn)指針類型
//顯示操作界面
int Interface_Display ();
//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num);
//顯示所有好友信息
int Friend_Information (PNode head);
//查找好友
int Search_Friend (PNode head, char* Name);
//刪除好友
void Delete_Friend (PNode head, char* Name);
#endif
源文件 head.c 關(guān)于結(jié)構(gòu)體的部分要進(jìn)行修改
#include "head.h"
//顯示操作界面
int Interface_Display ()
{
system ("clear");
printf ("\t*****************************************\n");
printf ("\t~ 歡迎使用通訊錄 ~\n");
printf ("\t~ ~\n");
printf ("\t~ 1 >>>>>>>> 添加好友信息 ~\n");
printf ("\t~ 2 >>>>>>>> 列表好友信息 ~\n");
printf ("\t~ 3 >>>>>>>> 搜索好友 ~\n");
printf ("\t~ 4 >>>>>>>> 刪除好友 ~\n");
printf ("\t~ 5 >>>>>>>> 退出 ~\n");
printf ("\t~ ~\n");
printf ("\t~ ~\n");
printf ("\t~ 作者:believe ~\n");
printf ("\t*****************************************\n");
printf (" \n");
printf (" \n");
printf ("\t請(qǐng)輸入對(duì)應(yīng)數(shù)字選擇相應(yīng)功能:");
}
//添加好友信息 (尾插法)
int Add_Friend (PNode head, ElementType num)
{
if (NULL == head)
{
return ERROR;
}
//創(chuàng)建一個(gè)新的結(jié)點(diǎn)
PNode p = (PNode) malloc(sizeof(Node)/sizeof(char));
if (NULL == p)
{
return MALLOC_ERROR;
}
//將新數(shù)據(jù)賦給新結(jié)點(diǎn)
system("clear");
printf ("\t*************添加好友***************\n");
p->data.ID = num;
printf ("\t好友的ID為:%d\n", p->data.ID);
printf ("\n");
printf ("\t請(qǐng)輸入好友的名字:");
scanf ("%s", p->data.Name);
printf ("\n");
printf ("\t請(qǐng)輸入好友的手機(jī)號(hào):");
scanf ("%s", p->data.Mobile_Phone);
printf ("\n");
printf ("\t請(qǐng)輸入好友的家庭住址:");
scanf ("%s", p->data.Home_Address);
printf ("\n");
printf ("\t請(qǐng)輸入好友的公司電話:");
scanf ("%s", p->data.Company_Tell);
printf ("\n");
p->next = NULL;
//找到最后一個(gè)結(jié)點(diǎn)
PNode Ptmp; //將頭結(jié)點(diǎn)地址給臨時(shí)指針Ptmp
Ptmp = head;
while (Ptmp->next)
{
Ptmp = Ptmp->next;
}
Ptmp->next = p;
return OK;
}
//顯示所有好友信息
int Friend_Information (PNode head)
{
if (NULL == head)
{
return ERROR;
}
PNode p = head->next;
printf ("\tID\t姓名\t\t手機(jī)號(hào)\t\t住址\t\t\t公司電話\n");
while (p)
{
printf ("\t%d\t%s\t\t%s\t\t%s\t\t\t%s\n", p->data.ID, p->data.Name,p->data.Mobile_Phone, p->data.Home_Address, p->data.Company_Tell);
p = p->next;
}
putchar('\n');
return OK;
}
//通過(guò)名字查找好友
int Search_Friend (PNode head, char* Name)
{
PNode p = head;
PNode q = NULL;
if ((NULL != p) && NULL != (p->next))
{
while (p->next)
{
q = p->next;
if ((NULL != q) && 0 == (strcmp(q->data.Name, Name)))
{
printf ("\t好友信息: \n\tID:%d\n\t姓名: %s\n\t手機(jī)號(hào)碼: %s\n\t家庭地址:%s\n\t公司電話: %s\n", q->data.ID, q->data.Name, q->data.Mobile_Phone, q->data.Home_Address, q->data.Company_Tell);
}
else
{
printf ("\t對(duì)不起,您的通訊錄沒(méi)有該好友!\n");
}
p = p->next;
}
}
/* 另一種做法
if (NULL == head)
{
return ERROR;
}
PNode p;
int flag = 1;
for (p = head->next; p != NULL; p = p->next)
{
if (0 == strcmp(p->data.Name, Name))
{
flag = 0;
printf ("\t好友信息:\n\tID: %d\n\t姓名: %s\n\t手機(jī)號(hào)碼: %s\n\t家庭地址: %s\n\t公司電話: %s\n", p->data.ID, p->data.Name, p->data.Mobile_Phone, p->data.Home_Address, p->data.Company_Tell);
}
}
fi (flag)
{
printf ("\t對(duì)不起,您的通訊錄沒(méi)有該好友!\n");
}
putchar('\n');
*/
return OK;
}
//刪除好友
void Delete_Friend (PNode head, char* Name)
{
PNode p = head;
PNode q = NULL;
while (NULL != p && NULL != (p->next))
{
q = p->next;
if (NULL != q && 0 == strcmp(q->data.Name, Name))
{
p->next = q->next;
free(q);
int j;
printf ("\t正在刪除\n");
printf ("\t請(qǐng)稍候");
fflush (stdout); //強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 2; j++)
{
sleep (1); //linux使用sleep,參數(shù)為秒
printf (".");
fflush(stdout); //強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
printf ("\t該好友已成功刪除!\n");
}
else if (NULL == q->next && 0 != strcmp(q->data.Name, Name))
{
printf ("\t您的通訊錄沒(méi)有該好友!\n");
}
p = p->next;
}
}
主函數(shù) main.c 加入了數(shù)據(jù)的讀取和寫(xiě)入,已標(biāo)明
/*******************************************************************
需求:制作一個(gè)電子通訊錄,通過(guò)該通訊錄能錄入好友ID號(hào)、姓名(英文)、手
機(jī)號(hào)碼,家庭住址,公司電話。
模塊:
主界面:主要顯示軟件功能,A)添加好友信息 B)列表好友信息。(包含排序
功能) C)搜索好友 D)刪除好友
A)用戶輸入INSERT命令后,讓用戶輸入好友信息。添加成功或失敗都需提示
B)用戶輸入DISPLAY命令后,好友信息升序排列
C)用戶輸入SEARCH命令后,讓用戶輸入將要搜索好友姓名查詢。如果未搜索
到請(qǐng)友好提示。如果搜索到,顯示處該好友信息
D)用戶輸入DELETE命令后,讓用戶輸入將要?jiǎng)h除好友姓名刪除,如果存在同
名的多個(gè)好友,則列表出,所有同名的好友信息,讓用戶通過(guò)輸入ID號(hào)刪除
提示用戶刪除成功。
**********************************************************************/
#include "head.h"
int main ()
{
int Function;
int i = 0;
char Name[N];
int cho;
// 創(chuàng)建頭結(jié)點(diǎn)并為其分配空間
PNode head_node = (PNode) malloc(sizeof(Node)/sizeof(char));
if (NULL == head_node)
{
return MALLOC_ERROR;
}
head_node->next = NULL;
/****************************************************************
打開(kāi)存放信息的文件并將里面的數(shù)據(jù)導(dǎo)入到鏈表中區(qū)
****************************************************************/
// 以只讀方式打開(kāi)存放信息的文件,
FILE *fp1 = fopen ("student.txt", "r+");
if (NULL == fp1)
{
printf ("fopen");
return -1;
}
PNode tmp = head_node;
int count;
int ret;
// 保存讀記錄的個(gè)數(shù)并判斷是否讀到文件結(jié)尾,如果讀到文件結(jié)尾,
// 它返回一個(gè)非0 的值
ret = fread (&count, sizeof(int), 1, fp1);
if(ret != 0)
{
for (i = 0; i < count; i++)
{
// 創(chuàng)建新結(jié)點(diǎn)用來(lái)保存讀取的數(shù)據(jù)
Node *node = (Node*)malloc(sizeof(Node)/sizeof(char));
int len;
fread (&len, sizeof(int), 1, fp1); // 讀取數(shù)據(jù)長(zhǎng)度
fread (&(node->data), len, 1, fp1); // 讀取數(shù)據(jù)
node->next = NULL;
while (tmp->next) // 向后遍歷
{
tmp = tmp->next;
}
tmp->next = node; // 將結(jié)點(diǎn)導(dǎo)入鏈表中
}
}
if (ret == 0 && !feof(fp1)) // 讀取失敗
{
perror ("fread");
return -1;
}
fclose (fp1); // 關(guān)閉剛剛打開(kāi)的文件
/****************************************************************
文件導(dǎo)入鏈表結(jié)束,關(guān)閉文件
****************************************************************/
i = 1; // i初始化(i既是ID編號(hào))
while (1)
{
Interface_Display (); // 主界面
scanf ("%d", &Function);
switch (Function) // 功能選擇
{
case 1: // 添加好友
{
Function = 0;
Add_Friend (head_node, i++);
int j;
printf ("\t正在添加\n");
printf ("\t請(qǐng)稍候");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 2; j++)
{
sleep (1); // Linux 使用sleep,參數(shù)為秒
printf (".");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
printf ("\t添加成功!\n");
printf ("\t返回主菜單請(qǐng)輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對(duì)不起!您的輸入有誤!請(qǐng)重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 2: // 顯示好友信息
{
system ("clear");
printf ("\t***********好友信息******************\n");
printf ("\n");
Friend_Information (head_node);
Function = 0;
printf ("\t返回主菜單請(qǐng)輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對(duì)不起!您的輸入有誤!請(qǐng)重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 3: // 查找好友
{
system ("clear");
printf ("\t*************查找好友*************\n");
printf ("\t請(qǐng)輸入您要查找的好友姓名:");
scanf ("%s", Name);
printf ("\n");
int j;
printf ("\t正在查找\n");
printf ("\t請(qǐng)稍候");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
for (j = 0; j < 2; j++)
{
sleep (1); // Linux 使用sleep,參數(shù)為秒
printf (".");
fflush (stdout); // 強(qiáng)制刷新緩存,輸出顯示
}
printf ("\n");
Search_Friend (head_node, Name);
printf ("\t返回主菜單請(qǐng)輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對(duì)不起!您的輸入有誤!請(qǐng)重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 4: //刪除好友
{
system ("clear");
printf ("\t*************刪除好友*************\n");
printf ("\t請(qǐng)輸入要?jiǎng)h除好友的姓名:");
scanf ("%s", Name);
printf ("\n");
Delete_Friend (head_node, Name);
printf ("\t返回主菜單請(qǐng)輸入1:");
scanf ("%d", &cho);
if (1 == cho)
{
break;
}
else
{
printf ("\t對(duì)不起!您的輸入有誤!請(qǐng)重新輸入:");
scanf ("%d", &cho);
break;
}
break;
}
case 5: //退出通訊錄
{
/****************************************************************
退出程序前,將鏈表中的數(shù)據(jù)導(dǎo)入到文件中去
****************************************************************/
// 以更新方式打開(kāi)存放信息的文件(打開(kāi)時(shí)會(huì)清空文件)
FILE *fp2 = fopen ("student.txt", "wb+");
if(NULL == fp2)
{
printf ("fopen");
return -1;
}
tmp = head_node->next; // tmp為第一個(gè)結(jié)點(diǎn)
count = 0; // 用來(lái)存放鏈表長(zhǎng)度
while(tmp) // 求鏈表長(zhǎng)度
{
count++;
tmp = tmp->next;
}
// 要寫(xiě)入數(shù)據(jù)的個(gè)數(shù)
fwrite(&count, sizeof(int), 1, fp2);
tmp = head_node; // tmp初始化
while (tmp->next)
{
Node* p = tmp->next;
tmp->next = p->next;
// 寫(xiě)入數(shù)據(jù)的長(zhǎng)度
int len = sizeof(p->data);
fwrite (&len, sizeof(int), 1, fp2);
//寫(xiě)入數(shù)據(jù)
fwrite (&(p->data), sizeof(Data), 1, fp2);
free (p);
}
fclose (fp2);
/****************************************************************
數(shù)據(jù)保存結(jié)束,即將退出程序
****************************************************************/
Function = 0;
system ("clear");
exit (0);
}
default: //輸入有誤
{
Function = 0;
printf ("\t對(duì)不起!您的輸入有誤!請(qǐng)重新輸入:");
scanf ("%d", &Function);
break;
}
}
}
return 0;
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語(yǔ)言實(shí)現(xiàn)一個(gè)簡(jiǎn)易通訊錄
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單電子通訊錄
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易通訊錄功能
- 基于C語(yǔ)言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng)
- C語(yǔ)言實(shí)現(xiàn)通訊錄
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄
- C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易通訊錄
- C語(yǔ)言實(shí)現(xiàn)個(gè)人通訊錄管理系統(tǒng)
- C語(yǔ)言通訊錄管理系統(tǒng)完整版
- C語(yǔ)言簡(jiǎn)易通訊錄的實(shí)現(xiàn)代碼
相關(guān)文章
QT實(shí)現(xiàn)簡(jiǎn)單時(shí)鐘效果
這篇文章主要為大家詳細(xì)介紹了QT實(shí)現(xiàn)簡(jiǎn)單時(shí)鐘效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
C++?Boost?MultiArray簡(jiǎn)化使用多維數(shù)組庫(kù)
Boost是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱。Boost庫(kù)是一個(gè)可移植、提供源代碼的C++庫(kù),作為標(biāo)準(zhǔn)庫(kù)的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開(kāi)發(fā)引擎之一,是為C++語(yǔ)言標(biāo)準(zhǔn)庫(kù)提供擴(kuò)展的一些C++程序庫(kù)的總稱2022-11-11
C/C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例
這篇文章主要為大家介紹了C++編程中判斷String字符串是否包含某個(gè)字符串的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-11-11
簡(jiǎn)單比較C語(yǔ)言中的execl()函數(shù)與execlp()函數(shù)
這篇文章主要介紹了C語(yǔ)言中的execl()函數(shù)與execlp()函數(shù)的簡(jiǎn)單比較,是C語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-08-08

