问题描述
有这样一个特殊情况: 有两个线程,他们之间是竞争关系,没有做同步, 线程A:读取数据库中ID从1到10000的记录(假使需要10s完成整个读取) 存储区:负责存放线程A读取的数据库结果集 线程B:读取存储区的数据库并打印 在这样的场景下,是否会出现,当线程A获得CPU时间后开始读取数据库,数据库的结果集正在网络上传输, 此时,线程B抢夺了线程A的运行权开始运行,请问,此时正在网络上传输的数据库的结果集怎么办?是被抛弃 还是被放到一个地方,等线程A恢复运行后再取出进行处理? 希望大家讨论一下这个过程,谢谢! 问题补充:当线程A正在接收数据库返回(网络传输)的时候,CPU被别人抢走了,此时的网络传输过来的数据,放在哪里,还是有缓存,数据临时存放一下,等线程A恢复运行后再去处理之前数据库返回的数据?
解决方案
A被咔嚓,传输的继续传输,B开始读取,读到哪算哪。都传输完了,B就能都读到,传输不完,B就只能读到存储区里面的已有数据。单例,线程同步,加锁,等等方法都能解决。
解决方案二:
看你的业务要求了,如果你的业务要求是只要读取开始了,那么就要在B中表现,那最好做个同步,事务级别上的同步
时间: 2024-09-12 14:56:50