F i r s t T h r e a d可以在S e c o n d T h r e a d将5分配给F i r s t T h r e a d的x之前结束它的 操作

在上面这个代码中, F i r s t T h r e a d可以在S e c o n d T h r e a d将5分配给F i r s t T h r e a d的x之前结束它的
操作。如果出现这种情况,S e c o n d T h r e a d将不知道F i r s t T h r e a d已经不再存在,并且仍然试图修改
现在已经是个无效地址的内容。这会导致S e c o n d T h r e a d产生一次访问违规
,因为F i r s t T h r e a d的堆
栈已经在F i r s t T h r e a d终止运行时被撤消。解决这个问题的方法之一是将x声明为一个静态变量,
这样,编译器就为应用程序的数据部分中的x创建一个存储区,而不是在堆栈上创建存储区。
但是这使得函数成为不可重新进入的函数。换句话说,无法创建两个执行相同函数的线程,
因为两个线程将共享该静态变量。解决这个问题(和它的更复杂的变形)的另一种方法是使用
正确的线程同步技术(第8、9章和1 0章介绍)。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值