日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【C 语言】字符串模型 ( 键值对模型 )

發布時間:2025/6/17 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【C 语言】字符串模型 ( 键值对模型 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 一、業務邏輯需求
  • 二、完整代碼實現





一、業務邏輯需求



在 C 中實現 鍵值對 字符串 的 讀取 , 解析 , 保存 操作 ;

  • 鍵值對字符串樣式 "key = value" , = 兩邊有若干不等的空格 ;
  • 根據 key 獲取 value ;

首先 , 查找 鍵 字符串 , 查找后 , 輔助指針變量移動到 鍵 字符串后面的位置 ;

// I . 查找子串 keyp = key_value;// 注意此處返回值是 key 在 key_value 字符串中首次出現的地址// 如果繼續向后遍歷, 跳過 key 的字符個數即可p = strstr(p, key);// 輔助指針變量 , 達到下一次檢索條件// 上面的 strstr 函數返回的是 key 在 key_value 字符串中首次出現的地址// 這里跳過 key 的字符個數 , 從 key 后的第一個字符開始遍歷p = p + strlen(key);

然后 , 查找 = 字符 , 與上面的操作基本相同 ;

// II . 查找 = 字符// strstr 函數返回的是 = 在 p 字符串中首次出現的地址p = strstr(p, "=");// 沒有查找到子串if(p == NULL){return -1;}// 輔助指針變量 , 越過 = , 繼續向后執行p = p + strlen("=");

最后 , 將 = 字符后的內容中的空格去除 ; 下面的方法是參考 【C 語言】字符串模型 ( 兩頭堵模型 | 將 兩頭堵模型 抽象成業務模塊函數 | 形參返回值 | 函數返回值 | 形參指針判空 | 形參返回值操作 ) 博客中的方法修改而來的 ;

int trim_space(char *str_all, char *str_no_space) {// 驗證指針合法性 , 指針為空直接返回報錯if(str_all == NULL || str_no_space == NULL){printf("error : str_all == NULL || count == NULL");return -1;}// 局部臨時指針變量 接收 函數形參char *str = str_all;char *str_no_space_tmp = str_no_space;// 兩個字符串索引 , i 是指向頭部 , j 指向尾部int i = 0, j = strlen(str) - 1;// 保存非空字符串長度 , 局部臨時變 , 計算結果int count_tmp = 0;// 循環條件是 i 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 i 指向從左側開始第一個不為空的字符while(isspace(str[i]) && str[i] != '\0'){i++;}// 循環條件是 j 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 j 指向從右側開始第一個不為空的字符while(isspace(str[j]) && str[j] != '\0'){j--;}// 計算結果count_tmp = j - i + 1;// 將去除空格的字符串拷貝到 str_no_trim_tmp 指針指向的空間中strncpy(str_no_space_tmp, str + i, count_tmp);return 0; }



二、完整代碼實現



完整代碼示例 :

#include <stdio.h> #include <stdlib.h> #include <string.h>int trim_space(char *str_all, char *str_no_space) {// 驗證指針合法性 , 指針為空直接返回報錯if(str_all == NULL || str_no_space == NULL){printf("error : str_all == NULL || count == NULL");return -1;}// 局部臨時指針變量 接收 函數形參char *str = str_all;char *str_no_space_tmp = str_no_space;// 兩個字符串索引 , i 是指向頭部 , j 指向尾部int i = 0, j = strlen(str) - 1;// 保存非空字符串長度 , 局部臨時變 , 計算結果int count_tmp = 0;// 循環條件是 i 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 i 指向從左側開始第一個不為空的字符while(isspace(str[i]) && str[i] != '\0'){i++;}// 循環條件是 j 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 j 指向從右側開始第一個不為空的字符while(isspace(str[j]) && str[j] != '\0'){j--;}// 計算結果count_tmp = j - i + 1;// 將去除空格的字符串拷貝到 str_no_trim_tmp 指針指向的空間中strncpy(str_no_space_tmp, str + i, count_tmp);return 0; }/** 根據 key 獲取 value* char *key_value : 鍵值對字符串 "name = Tom"* char *key : 鍵 "name"* char *value : 值 "Tom"* int *value_len : 值 的字符個數 , 4 , 包括結尾的 \0 字符*/ int get_value(char *key_value, char *key, char *value, int *value_len) {// 輔助指針變量 , 接收查找子串的返回值 , 同時指向當前處理的字符串char *p = NULL;// 各種函數執行返回值int ret = 0;// I . 查找子串 keyp = key_value;// 注意此處返回值是 key 在 key_value 字符串中首次出現的地址// 如果繼續向后遍歷, 跳過 key 的字符個數即可p = strstr(p, key);// 沒有查找到子串if(p == NULL){return -1;}// 輔助指針變量 , 達到下一次檢索條件// 上面的 strstr 函數返回的是 key 在 key_value 字符串中首次出現的地址// 這里跳過 key 的字符個數 , 從 key 后的第一個字符開始遍歷p = p + strlen(key);// II . 查找 = 字符// strstr 函數返回的是 = 在 p 字符串中首次出現的地址p = strstr(p, "=");// 沒有查找到子串if(p == NULL){return -1;}// 輔助指針變量 , 越過 = , 繼續向后執行p = p + strlen("=");// III . 將 = 字符后面的空格去除ret = trim_space(p, value);if(ret != 0){printf("error : trim_space %d \n", ret);}return 0; }int main() {// 要解析的鍵值對字符串char *key_value = "name = Tom ";// 鍵char *key = "name";// 存放解析后的 值char value[1024];// 存放解析后的 值 的字符個數char value_len = 0;// 接收 get_value 方法的返回值int ret = 0;// 獲取 key_value 鍵值對字符串中的 key 對應的 value 值ret = get_value(key_value, key, value, &value_len);// 執行失敗后的處理結果if(ret != 0){printf("error : get_value failed %d\n", ret);return ret;}// 執行成功, 打印 value 值printf("value = %s\n", value);// 命令行不要退出system("pause");return ret; }

執行結果 :

總結

以上是生活随笔為你收集整理的【C 语言】字符串模型 ( 键值对模型 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。