C/C++教程

【C 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 )

本文主要是介绍【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 语言】字符串模型 ( 字符串翻转模型 | 借助 递归函数操作 逆序字符串操作 | 引入线程安全概念 )的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!