现在的项目有个需求,就是有一个随机抽取的算法,我希望每次只能有一个人访问,其他人来访问的时候,处于等待状态。如果等待时间太长,直接返回结果。使用单线程应该如何处理,或者有没有其他更好的方式?请大神指导一下
2条回答 默认 最新
- charm_of_code 2017-03-17 13:21关注
这个是共享资源访问的问题,你问的应该属于多线程同步问题吧。对于共享资源,每一时刻只有一个线程可以访问。
在多线程中的访问共享资源的函数前加synchronized关键字就好了。比如我的共享资源是一个栈;
public synchronized void push(int value){
stack[top]=value;
top++;
}
此时对stack的访问就是同步的。在你的代码中把对共享的资源代替里边的stack就好了,至于你说的单线程,感觉你这问题就是多线程问题
,就是多个人访问同步,跟单线程访问不怎么着边。如果是单线程,根本就不用担心有其他人来访问的问题了。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 腾讯企业邮箱邮件可以恢复么
- ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
- ¥15 错误 LNK2001 无法解析的外部符号
- ¥50 安装pyaudiokits失败
- ¥15 计组这些题应该咋做呀
- ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
- ¥15 让node服务器有自动加载文件的功能
- ¥15 jmeter脚本回放有的是对的有的是错的
- ¥15 r语言蛋白组学相关问题
- ¥15 Python时间序列如何拟合疏系数模型