【Linux】线程安全strtok与strtok_r

  • strtok是字符串分割函数
  • strtok_r是strtok的线程安全版本

(一)问题:多线程中strtok时出现异常情况

  • 代码:
#include <string.h>
#include <stdio.h>
#include <pthread.h>
void* pthread_fun(void* arg)
{
	char bbuff[] = {"a b c d e"};
	char* p = strtok(bbuff, " ");
	while(p != NULL)
	{
		printf("%s\n", p);
		p = strtok(NULL, " ");
	}
}

int main()
{
	char abuff[] = {"A B C D E"};
	pthread_t id;
	pthread_create(&id, NULL, pthread_fun, NULL);

	char* s = strtok(abuff, " ");
	while(s != NULL)
	{
		printf("%s\n", s);
		s = strtok(NULL, " ");
	}
	pthread_join(id, NULL);
	return 0;
}
  • 结果:
    在这里插入图片描述

  • 原因分析:原因在于strtok函数内部定义了一个静态指针变量 lasts用来记录上次切割的地址,在多线程中共享静态变量的缘故,出现了混乱。

(二)解决方案:使用strtok_r

代码:

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

void* pthread_fun(void* arg)
{
	char bbuff[] = {"a b c d e"};
	char* psave = NULL; 
	char* p = strtok_r(bbuff, " ", &psave);
	while(p != NULL)
	{
		printf("%s\n", p);
		p = strtok_r(NULL, " ", &psave);
	}
}

int main()
{
	pthread_t id;
	pthread_create(&id, NULL, pthread_fun, NULL);

	char abuff[] = {"A B C D E"};
	char* ssave = NULL;
	char* s = strtok_r(abuff, " ", &ssave);
	while(s != NULL)
	{
		printf("%s\n", s);
		s = strtok_r(NULL, " ", &ssave);
	}
	pthread_join(id, NULL);
	return 0;
}
  • 结果:
    在这里插入图片描述
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值