【C 语言】数组 ( 指针数组用法 | 菜单选择 )

举报
韩曙亮 发表于 2022/01/12 23:17:25 2022/01/12
【摘要】 文章目录 一、指针数组用法 ( 菜单选择 )二、完整代码示例 一、指针数组用法 ( 菜单选择 ) 使用场景 : 用户输入一个 字符串 , 判定该 字符串 是菜单中的...





一、指针数组用法 ( 菜单选择 )



使用场景 : 用户输入一个 字符串 , 判定该 字符串 是菜单中的哪个选项 ;


定义 指针数组 , 数组中存放着指针 , 每个指针指向 字符串 常量 , 字符串常量在 全局区 中的 常量区 ;

    // 指针数组 , 数组中存放着指针 , 每个指针指向 字符串 常量
    // 字符串常量在 全局区 中
    char *menu_array[] = {
        "query",
        "update",
        "insert",
        "delete"
    };

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

将 指针数组 菜单 和 指针数组 大小 , 以及要查询的 字符串 ;.

  • 计算数组大小 : 使用如下宏定义 , 计算数组大小 ;
// 计算数组长度
#define LEN(array) (sizeof(array) / sizeof(*array))

  
 
  • 1
  • 2
  • 函数参数定义 :
/**
 * @brief searche_menu_table 菜单列表 中查找 字符串位置
 * @param menu_table 指针数组 , 数组元素是指针 , 指针指向字符串
 * @param array_size 指针数组 中 元素个数
 * @param str 要查找的字符串
 * @param menu_position 字符串位置
 * @return 返回函数是否执行成功
 */
int searche_menu_table(const char *menu_table[], const int array_size, const char* str, int *menu_position)
{}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

遍历 指针数组 , 查找字符串位置 :

    // 遍历字符串数组
    for(i=0; i < array_size; i++)
    {
        // 如果找到字符串 , 则返回
        if(strcmp(str, menu_table[i]) == 0)
        {
            *menu_position = i;
            return ret;
        }
    }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10




二、完整代码示例



完整代码示例 :

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

// 计算数组长度
#define LEN(array) (sizeof(array) / sizeof(*array))

/**
 * @brief searche_menu_table 菜单列表 中查找 字符串位置
 * @param menu_table 指针数组 , 数组元素是指针 , 指针指向字符串
 * @param array_size 指针数组 中 元素个数
 * @param str 要查找的字符串
 * @param menu_position 字符串位置
 * @return 返回函数是否执行成功
 */
int searche_menu_table(const char *menu_table[], const int array_size, const char* str, int *menu_position)
{
    // 函数返回值, 标志函数执行结果状态 , 0 表示执行成功
    int ret = 0;
    // 循环控制变量
    int i = 0;

    // 验证指针合法性
    if (menu_table==NULL || str==NULL || menu_position==NULL)
    {
        ret = -1;
        printf("error : menu_table==NULL || str==NULL || menu_position==NULL");
        return ret;
    }

    // 遍历字符串数组
    for(i=0; i < array_size; i++)
    {
        // 如果找到字符串 , 则返回
        if(strcmp(str, menu_table[i]) == 0)
        {
            *menu_position = i;
            return ret;
        }
    }

    // 在 menu_table 字符串数组中 , 没有找到 str 字符串
    // 返回 -2 错误状态
    ret = -2;
    // 设置 -1 位置
    *menu_position = -1;

    return ret;
}

/**
 * @brief 主函数入口
 * @return
 */
int main()
{
    // 记录字符串在菜单中的位置
    int menu_position = 0;
    int i = 0;

    // 指针数组 , 数组中存放着指针 , 每个指针指向 字符串 常量
    // 字符串常量在 全局区 中
    char *menu_array[] = {
        "query",
        "update",
        "insert",
        "delete"
    };

    // 在 字符串指针数组 中 查询对应字符串
    searche_menu_table( menu_array, LEN(menu_array),"delete", &menu_position);
    // 打印查找到的位置
    printf("menu_position = %d\n", menu_position);

    // 命令行不要退出
    system("pause");
    return 0;
}


  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79

执行结果 :

menu_position = 3
请按任意键继续. . .

  
 
  • 1
  • 2

在这里插入图片描述

文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。

原文链接:hanshuliang.blog.csdn.net/article/details/121644617

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。