【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 )
【摘要】
文章目录
一、引入线程安全概念二、完整代码示例
一、引入线程安全概念
在上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操...
一、引入线程安全概念
在上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | strncat 函数 ) 中 , 虽然 使用递归 实现了 字符串逆序 , 但是最终字符串是写在全局变量中的 , 如果多个线程访问该方法 , 肯定就出错了 ;
在函数调用时 , 传入一个局部变量 char *str_buf
, 使用该局部变量存储 逆序后的字符串 ;
/*
* 通过递归方式 , 逆向遍历字符串
* 将 递归遍历 结果存入 全局变量中
* 递归指针 作 函数参数
*/
void str_inverse(char *str, char *str_buf)
- 1
- 2
- 3
- 4
- 5
- 6
二、完整代码示例
完整代码示例 :
#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;
}
- 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
执行结果 :
*str = h
*str = d
*str = s
str_buf = hds
请按任意键继续. . .
- 1
- 2
- 3
- 4
- 5
文章来源: hanshuliang.blog.csdn.net,作者:韩曙亮,版权归原作者所有,如需转载,请联系作者。
原文链接:hanshuliang.blog.csdn.net/article/details/121526832
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)