【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 )
2021/11/24 23:17:26
本文主要是介绍【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 ),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 一、引入线程安全概念
- 二、完整代码示例
一、引入线程安全概念
在上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | strncat 函数 ) 中 , 虽然 使用递归 实现了 字符串逆序 , 但是最终字符串是写在全局变量中的 , 如果多个线程访问该方法 , 肯定就出错了 ;
在函数调用时 , 传入一个局部变量 char *str_buf
, 使用该局部变量存储 逆序后的字符串 ;
/* * 通过递归方式 , 逆向遍历字符串 * 将 递归遍历 结果存入 全局变量中 * 递归指针 作 函数参数 */ void str_inverse(char *str, char *str_buf)
二、完整代码示例
完整代码示例 :
#include <stdio.h> #include <stdlib.h> #include <string.h> /* * 通过递归方式 , 逆向遍历字符串 * 将 递归遍历 结果存入 全局变量中 * 递归指针 作 函数参数 */ void str_inverse(char *str, char *str_buf) { // 验证函数形参指针合法性 if(str == NULL || str_buf == NULL) { return; } // 递归停止条件 if(*str == '\0') { return; } // 递归操作 // 该递归操作会逐步 将 字符串 从开始位置 入栈 // 直到递归到 '\0' 位置时 , 才开始出栈 // 此处是递归点 // 递归操作执行到这里 , 开始一直递归 // 递归结束后 , 依次执行下面的代码 str_inverse(str + 1, str_buf); // 打印出栈的字符 // 注意 : 该打印操作是 递归停止条件达成后 // 逐个出栈打印 printf("*str = %c\n", *str); // 拷贝一个字符到全局变量中 //strncpy(str_buf, str, 1); // 连接字符串 , 从 '\0' 位置处开始覆盖 strncat(str_buf, str, 1); } int main() { // 存在如下字符串, 求下面字符串 "abc" 出现次数 char *str = "sdh"; // 用于存储逆序后的字符串 char str_buf[1024] = {0}; // 字符串翻转 str_inverse(str, str_buf); // 打印字符串翻转结果 printf("str_buf = %s\n", str_buf); // 命令行不要退出 system("pause"); return 0; }
执行结果 :
*str = h *str = d *str = s str_buf = hds 请按任意键继续. . .
这篇关于【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 )的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用