溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C語言如何實(shí)現(xiàn)簡單電子通訊錄

發(fā)布時(shí)間:2020-06-28 17:00:02 來源:億速云 閱讀:274 作者:清晨 欄目:開發(fā)技術(shù)

不懂C語言如何實(shí)現(xiàn)簡單電子通訊錄?其實(shí)想解決這個(gè)問題也不難,下面讓小編帶著大家一起學(xué)習(xí)怎么去解決,希望大家閱讀完這篇文章后大所收獲。

這兩天學(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è)文件以更新方式打開,并將文件中之前保存的信息清空,然后將結(jié)構(gòu)體的數(shù)據(jù)保存到文件中去,再退出程序。

還有在文件寫入時(shí)和讀取時(shí),先寫入(讀?。┍4鏀?shù)據(jù)的總個(gè)數(shù),讓程序知道有多少數(shù)據(jù)要寫入(讀?。缓蟊4婷總€(gè)數(shù)據(jù)的字節(jié)數(shù)(程序會(huì)根據(jù)每個(gè)數(shù)據(jù)的字節(jié)數(shù)來進(jìn)行保存),最后再保存數(shù)據(jù)。

與之前版本相比,改動(dòng)的只有主函數(shù)中加入了讀取文件和寫入數(shù)據(jù)這兩個(gè)步驟,還有的變動(dòng)就是結(jié)構(gòu)體從一個(gè)變成了兩個(gè),將指針從原來一個(gè)結(jié)構(gòu)體中分離出來,方便數(shù)據(jù)從文件中的導(dǎo)入導(dǎo)出。下面是代碼(免得你們往前翻,我把之前的代碼都修改了考過來):

頭文件 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號
  char Name [N];       // 姓名
  char Mobile_Phone [N];   // 手機(jī)號碼
  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請輸入對應(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請輸入好友的名字:");
  scanf ("%s", p->data.Name);
  printf ("\n");

  printf ("\t請輸入好友的手機(jī)號:");
  scanf ("%s", p->data.Mobile_Phone);
  printf ("\n");

  printf ("\t請輸入好友的家庭住址:");
  scanf ("%s", p->data.Home_Address);
  printf ("\n");

  printf ("\t請輸入好友的公司電話:");
  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ī)號\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;
}

//通過名字查找好友
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ī)號碼: %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對不起,您的通訊錄沒有該好友!\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ī)號碼: %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對不起,您的通訊錄沒有該好友!\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請稍候");
      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您的通訊錄沒有該好友!\n");
    }
    p = p->next;
  }
}

主函數(shù) main.c 加入了數(shù)據(jù)的讀取和寫入,已標(biāo)明

/*******************************************************************
需求:制作一個(gè)電子通訊錄,通過該通訊錄能錄入好友ID號、姓名(英文)、手
機(jī)號碼,家庭住址,公司電話。
模塊:
  主界面:主要顯示軟件功能,A)添加好友信息 B)列表好友信息。(包含排序
  功能) C)搜索好友 D)刪除好友
  A)用戶輸入INSERT命令后,讓用戶輸入好友信息。添加成功或失敗都需提示
  B)用戶輸入DISPLAY命令后,好友信息升序排列
  C)用戶輸入SEARCH命令后,讓用戶輸入將要搜索好友姓名查詢。如果未搜索
  到請友好提示。如果搜索到,顯示處該好友信息
  D)用戶輸入DELETE命令后,讓用戶輸入將要?jiǎng)h除好友姓名刪除,如果存在同
  名的多個(gè)好友,則列表出,所有同名的好友信息,讓用戶通過輸入ID號刪除
  提示用戶刪除成功。
**********************************************************************/
#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;


/****************************************************************
  打開存放信息的文件并將里面的數(shù)據(jù)導(dǎo)入到鏈表中區(qū)
****************************************************************/
  // 以只讀方式打開存放信息的文件,
  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)用來保存讀取的數(shù)據(jù)
      Node *node = (Node*)malloc(sizeof(Node)/sizeof(char));   

      int len;          
      fread (&len, sizeof(int), 1, fp1);   // 讀取數(shù)據(jù)長度
      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)閉剛剛打開的文件
/****************************************************************
  文件導(dǎo)入鏈表結(jié)束,關(guān)閉文件
****************************************************************/  

  i = 1;               // i初始化(i既是ID編號)
  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請稍候");
        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返回主菜單請輸入1:");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t對不起!您的輸入有誤!請重新輸入:");
          scanf ("%d", &cho);
          break;
        }
        break;
      }      
      case 2:         // 顯示好友信息
      {
        system ("clear");
        printf ("\t***********好友信息******************\n");
        printf ("\n");

        Friend_Information (head_node);
        Function = 0;
        printf ("\t返回主菜單請輸入1:");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t對不起!您的輸入有誤!請重新輸入:");
          scanf ("%d", &cho);
          break;
        }
        break;
      }
      case 3:         // 查找好友
      {
        system ("clear");
        printf ("\t*************查找好友*************\n");
        printf ("\t請輸入您要查找的好友姓名:");
        scanf ("%s", Name);
        printf ("\n");

        int j;     
        printf ("\t正在查找\n");
        printf ("\t請稍候");
        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返回主菜單請輸入1:");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t對不起!您的輸入有誤!請重新輸入:");
          scanf ("%d", &cho);
          break;
        }
        break;
      }
      case 4:           //刪除好友
      {
        system ("clear");
        printf ("\t*************刪除好友*************\n");
        printf ("\t請輸入要?jiǎng)h除好友的姓名:");
        scanf ("%s", Name);
        printf ("\n");
        Delete_Friend (head_node, Name);
        printf ("\t返回主菜單請輸入1:");
        scanf ("%d", &cho);
        if (1 == cho)
        {
          break;
        }
        else
        {
          printf ("\t對不起!您的輸入有誤!請重新輸入:");
          scanf ("%d", &cho);
          break;
        }
        break;
      }  
      case 5:           //退出通訊錄
      {

/****************************************************************
        退出程序前,將鏈表中的數(shù)據(jù)導(dǎo)入到文件中去
****************************************************************/
        // 以更新方式打開存放信息的文件(打開時(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;           // 用來存放鏈表長度
        while(tmp)           // 求鏈表長度
        { 
          count++; 
          tmp = tmp->next; 
        }

        // 要寫入數(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; 

          // 寫入數(shù)據(jù)的長度         
          int len = sizeof(p->data); 
          fwrite (&len, sizeof(int), 1, fp2); 

          //寫入數(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對不起!您的輸入有誤!請重新輸入:");
        scanf ("%d", &Function);
        break;
      }      
    }    
  }  

  return 0;
}

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享C語言如何實(shí)現(xiàn)簡單電子通訊錄內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI