Exercise C: Building a simple phonebook application
Apr 03, 2025 pm 08:15 PMOne of the best ways to learn C language programming is to practice it. This article will take you step through a project I recently completed: a simple phone book application. This app demonstrates file processing and basic data management in C, allowing you to add, view, and delete contacts.
Detailed code explanation
Here is the complete code:
<code class="c">#include <stdio.h> #include <string.h> // 函數(shù)聲明void addcontact(char name[], char number[]); void viewcontacts(); void deletecontact(char name[]); int main() { int choice; char name[20]; char number[20]; printf("-- 歡迎使用您的電話簿! -- \n"); do { // 顯示菜單printf("\n您想執(zhí)行什么操作?\n"); printf("1. 創(chuàng)建新聯(lián)系人\t 2. 查看電話簿\t 3. 刪除聯(lián)系人\t 4. 退出\n"); scanf("%d", &choice); switch (choice) { case 1: // 添加新聯(lián)系人printf("很好,讓我們創(chuàng)建一個(gè)新聯(lián)系人:\n"); printf("請輸入聯(lián)系人的姓名:\n"); scanf("%s", name); printf("現(xiàn)在輸入電話號(hào)碼:\n"); scanf("%s", number); addcontact(name, number); break; case 2: // 查看電話簿printf("這是您的電話簿:\n"); viewcontacts(); break; case 3: // 刪除聯(lián)系人printf("請輸入要?jiǎng)h除的聯(lián)系人的姓名:\n"); scanf("%s", name); deletecontact(name); break; } } while (choice != 4); // 循環(huán)直到用戶選擇“退出” return 0; } // 向電話簿添加聯(lián)系人的函數(shù)void addcontact(char name[], char number[]) { FILE *pfile; pfile = fopen("phonebook.txt", "a"); if (pfile == NULL) { printf("打開電話簿失敗。"); return; } fprintf(pfile, "姓名: %s \t 電話: %s\n", name, number); printf("聯(lián)系人已創(chuàng)建!\n"); fclose(pfile); } // 查看電話簿中所有聯(lián)系人的函數(shù)void viewcontacts() { char filecontent[200]; FILE *pfile; pfile = fopen("phonebook.txt", "r"); while (fgets(filecontent, sizeof(filecontent), pfile)) { printf("\n%s", filecontent); } fclose(pfile); } // 從電話簿中刪除聯(lián)系人的函數(shù)void deletecontact(char name[]) { FILE *pfile, *ptrash; char line[200], contactname[20], contactnumber[20]; pfile = fopen("phonebook.txt", "r"); ptrash = fopen("trash.txt", "w"); if (pfile == NULL || ptrash == NULL) { printf("打開文件失敗。"); return; } while (fgets(line, sizeof(line), pfile)) { sscanf(line, "姓名: %s \t 電話: %s\n", contactname, contactnumber); if (strcmp(name, contactname) != 0) { fputs(line, ptrash); } } fclose(pfile); fclose(ptrash); // 將舊電話簿替換為更新后的版本remove("phonebook.txt"); rename("trash.txt", "phonebook.txt"); printf("聯(lián)系人已刪除。"); }</string.h></stdio.h></code>
Project Features
This program implements three core functions:
- Add a contact:
- Allows users to enter their name and phone number.
- Store contact information in a file named
phonebook.txt
.
- View contact:
- Read and display all contact information stored in the
phonebook.txt
file.
- Read and display all contact information stored in the
- Delete a contact:
- Delete the contact based on the name entered by the user.
- Filter out deleted contacts by creating temporary files and replace the original files.
Learning gains
Through this exercise, I consolidated the following C language knowledge:
- File processing: Proficient in using
fopen
,fclose
and other file operation functions, and handle the failure of file opening. - String operation: Use functions such as
strcmp
andsscanf
to compare and parse strings. - Basic Data Management: Learn how to store and manage data in simple text files, and update file content by creating temporary files.
Code Testing
- Copy the code into a
.c
file (e.g.phonebook.c
) and compile with a C compiler (e.g. GCC):
<code class="bash">gcc -o phonebook phonebook.c</code>
- Run the compiled program:
<code class="bash">./phonebook</code>
- Follow the on-screen prompts to add, view, or delete contacts.
- Open the
phonebook.txt
file to verify that the data is stored correctly.
Future improvements
This program is a good start and the following improvements can be considered in the future:
- Enter Verification: Verify the validity of the phone number (for example, including only numbers) to prevent duplicate names.
- User interface improvement: Provides clearer prompts, allowing input of names containing multiple words (using
fgets
instead ofscanf
). - Enhanced file processing: Consider data encryption for improved security, using more structured file formats such as CSV or JSON.
- Advanced Features: Add search function to sort contacts alphabetically.
Summarize
This exercise helped me understand the C language file processing and basic data management in the basics. This is a simple but practical program that can serve as the basis for more complex projects. If you are a beginner in C language, you highly recommend giving it a try! This is an interesting and rewarding learning process.
The above is the detailed content of Exercise C: Building a simple phonebook application. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The top 20 most promising crypto assets in 2025 include BTC, ETH, SOL, etc., mainly covering multiple tracks such as public chains, Layer 2, AI, DeFi and gaming. 1.BTC continues to lead the market with its digital yellow metallicity and popularization of ETFs; 2.ETH consolidates the ecosystem due to its position and upgrade of smart contract platforms; 3.SOL stands out with high-performance public chains and developer communities; 4.LINK is the leader in oracle connecting real data; 5.RNDR builds decentralized GPU network service AI needs; 6.IMX focuses on Web3 games to provide a zero-gas-free environment; 7.ARB leads with mature Layer 2 technology and huge DeFi ecosystem; 8.MATIC has become the value layer of Ethereum through multi-chain evolution

The core difference between USDC, DAI and TUSD lies in the issuance mechanism, collateral assets and risk characteristics. 1. USDC is a centralized stablecoin issued by Circle and is collateralized by cash and short-term treasury bonds. Its advantages are compliance and transparent, strong liquidity, and high stability, but there is a risk of centralized review and single point failure; 2. DAI is a decentralized stablecoin, generated through the MakerDAO protocol, and the collateral is a crypto asset. It has the advantages of anti-censorship, transparency on chain, and permission-free, but it also faces systemic risks, dependence on centralized assets and complexity issues; 3. TUSD is a centralized stablecoin, emphasizing real-time on-chain reserve proof, providing higher frequency transparency verification, but has a small market share and weak liquidity. The three are collateral types and decentralization

Ouyi okex is a professional digital asset trading and management tool, providing users with safe, stable and reliable trading services. It supports the transaction of a variety of mainstream digital assets and provides a wealth of financial tools and products to help users easily manage and configure their own digital assets.

The latest version of Ouyi is v6.1271, and the update tutorial is: 1. Uninstall the old version or unofficial APK; 2. Click the official download address provided by the article to download the latest APK; 3. Enable the mobile phone installation permission; 4. Install and log in to the verification function. It is recommended to use v6.127.0 or higher. If the current version is lower than v6.124 or comes from a third-party platform, you should immediately switch to the official channel to ensure transaction security and stable functions.

The price potential of major crypto assets from 2025 to 2030 is driven by technological development, market cycles and macroeconomics. 1. Bitcoin (BTC) is expected to break through the historical high in 2025 due to the halving event and the launch of ETFs, and may reach a new order of magnitude in 2030; 2. Ethereum (ETH) benefits from network upgrades and ecological expansion, and its long-term value is bullish; 3. Projects such as Solana, BNB, and Chainlink rely on ecological development and technological stability, and the overall market will mature but be accompanied by high risks.

Kevin O'Leary highlights AI's transformative impact on reducing customer acquisition costs, reshaping investment strategies, and the US-China tech rivalry.

In the global wave of digital asset trading, it is crucial to choose a safe, efficient and trading platform that meets your own needs. Especially for users in Asia, facing many platforms, complex functions and changing regulatory environments, how to find the best cryptocurrency platform for you and find the best cryptocurrency platform for you has become a problem for many people. This article aims to provide you with an in-depth analysis of the TOP5 cryptocurrency platforms that are most suitable for Asian users in 2025, helping you move forward steadily in the world of digital assets.

Ordinary investors can discover potential tokens by tracking "smart money", which are high-profit addresses, and paying attention to their trends can provide leading indicators. 1. Use tools such as Nansen and Arkham Intelligence to analyze the data on the chain to view the buying and holdings of smart money; 2. Use Dune Analytics to obtain community-created dashboards to monitor the flow of funds; 3. Follow platforms such as Lookonchain to obtain real-time intelligence. Recently, Cangming Money is planning to re-polize LRT track, DePIN project, modular ecosystem and RWA protocol. For example, a certain LRT protocol has obtained a large amount of early deposits, a certain DePIN project has been accumulated continuously, a certain game public chain has been supported by the industry treasury, and a certain RWA protocol has attracted institutions to enter.
