C语言 指针综合应用 ( 高阶应用 )

前言

下面代码主要使用指针实现一个,图书馆管理系统的应用代码。

设计到关于指针的知识点有:

结构体指针、函数指针数组、数组指针、函数指针、结构体指针数组,还有枚举、类型定义、宏定义

主打一个为了使用指针而使用指针。

功能说明

图书管理系统,具有以下特点:

• 使用结构体存储书籍信息(书名、作者、类别)。

• 使用枚举定义书籍类别。

• 使用函数指针数组实现菜单选择操作。

使用数组指针和结构体指针数组管理书籍集合。

特性说明

• 结构体指针:书籍通过结构体指针动态管理,允许运行时动态分配和释放内存。

• 枚举:定义书籍的类别,使类别信息更清晰。

• 类型定义:提高代码的可读性和可维护性。

• 宏定义:用于定义常量,如最大书籍数量和菜单选项数,提高代码的可配置性。

• 数组指针和结构体指针数组:用于存储和管理书籍集合。

• 函数指针数组:实现菜单选择的多态性,根据用户输入调用不同的操作函数。

• 函数指针:menuFunctions数组中的每个元素是一个指向函数的指针,这些函数执行具体的操作,如添加书籍、删除书籍等。

这个案例综合运用了您要求的C语言知识点,展示了如何在实际应用中使用这些特性。

代码

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_BOOKS 100
#define MAX_TITLE_LENGTH 50
#define MAX_AUTHOR_LENGTH 50
// 枚举定义书籍类别
typedef enum BookCategory {
    FICTION,
    NONFICTION,
    SCIENCE,
    SPORTS,
    CATEGORY_COUNT // 用于统计类别数量
} BookCategory;
// 类型定义书籍结构体
typedef struct Book {
    char title[MAX_TITLE_LENGTH];
    char author[MAX_AUTHOR_LENGTH];
    BookCategory category;
} Book;
// 宏定义
#define MENU_OPTIONS 4
// 函数声明
void addBook(Book **books, int *count);
void deleteBook(Book **books, int *count);
void printBooks(Book **books, int count);
void exitProgram(Book **books, int *count);
// 函数指针数组,用于菜单操作
void (*menuFunctions[MENU_OPTIONS])(Book **, int *) = {
    addBook,
    deleteBook,
    printBooks,
    exitProgram
};
// 主函数
int main() {
    Book *books[MAX_BOOKS] = {0}; // 结构体指针数组
    int bookCount = 0;
    int choice;
    while (1) {
        printf("\nMenu:\n");
        printf("1. Add Book\n");
        printf("2. Delete Book\n");
        printf("3. Print Books\n");
        printf("4. Exit\n");
        printf("Enter choice: ");
        scanf("%d", &choice);
        if (choice < 1 || choice > MENU_OPTIONS) {
            printf("Invalid choice. Please try again.\n");
            continue;
        }
        // 调用相应的函数
        menuFunctions[choice - 1](&books[0], &bookCount);
        if (choice == MENU_OPTIONS) break; // 退出循环
    }
    return 0;
}
// 实现函数
void addBook(Book **books, int *count) {
    if (*count >= MAX_BOOKS) {
        printf("Maximum number of books reached.\n");
        return;
    }
    Book *newBook = (Book *)malloc(sizeof(Book));
    if (!newBook) {
        printf("Memory allocation failed.\n");
        return;
    }
    printf("Enter book title: ");
    scanf("%49s", newBook->title); // 防止溢出
    printf("Enter author name: ");
    scanf("%49s", newBook->author);
    printf("Enter category (0 for Fiction, 1 for Nonfiction, 2 for Science, 3 for Sports): ");
    scanf("%u", (unsigned int *)&newBook->category);
    books[*count] = newBook;
    (*count)++;
    printf("Book added successfully.\n");
}
void deleteBook(Book **books, int *count) {
    int index;
    printf("Enter index of book to delete: ");
    scanf("%d", &index);
    if (index < 0 || index >= *count) {
        printf("Invalid index.\n");
        return;
    }
    free(books[index]);
    for (int i = index; i < *count - 1; i++) {
        books[i] = books[i + 1];
    }
    books[*count - 1] = NULL;
    (*count)--;
    printf("Book deleted successfully.\n");
}
void printBooks(Book **books, int count) {
    if (count == 0) {
        printf("No books to display.\n");
        return;
    }
    printf("Books:\n");
    for (int i = 0; i < count; i++) {
        printf("%d: %s by %s, Category: %d\n", i, books[i]->title, books[i]->author, books[i]->category);
    }
}
void exitProgram(Book **books, int *count) {
    for (int i = 0; i < *count; i++) {
        free(books[i]);
    }
    printf("Exiting program...\n");
}
相关推荐
shinelord明19 分钟前
【再谈设计模式】建造者模式~对象构建的指挥家
开发语言·数据结构·设计模式
十七算法实验室24 分钟前
Matlab实现麻雀优化算法优化随机森林算法模型 (SSA-RF)(附源码)
算法·决策树·随机森林·机器学习·支持向量机·matlab·启发式算法
黑不拉几的小白兔35 分钟前
PTA部分题目C++重练
开发语言·c++·算法
迷迭所归处36 分钟前
动态规划 —— dp 问题-买卖股票的最佳时机IV
算法·动态规划
写bug的小屁孩37 分钟前
websocket身份验证
开发语言·网络·c++·qt·websocket·网络协议·qt6.3
chordful1 小时前
Leetcode热题100-32 最长有效括号
c++·算法·leetcode·动态规划
_OLi_1 小时前
力扣 LeetCode 459. 重复的子字符串(Day4:字符串)
算法·leetcode·职场和发展·kmp
材料苦逼不会梦到计算机白富美1 小时前
线性DP 区间DP C++
开发语言·c++·动态规划
java小吕布1 小时前
Java Lambda表达式详解:函数式编程的简洁之道
java·开发语言
Romanticroom1 小时前
计算机23级数据结构上机实验(第3-4周)
数据结构·算法