iteye_20488 2010-10-12 08:51
浏览 257
已采纳

多线程数据库操作问题,请大家给予解读,谢谢!

有这样一个特殊情况:
有两个线程,他们之间是竞争关系,没有做同步,

 线程A:读取数据库中ID从1到10000的记录(假使需要10s完成整个读取)
存储区:负责存放线程A读取的数据库结果集
 线程B:读取存储区的数据库并打印

在这样的场景下,是否会出现,当线程A获得CPU时间后开始读取数据库,数据库的结果集正在网络上传输,

此时,线程B抢夺了线程A的运行权开始运行,请问,此时正在网络上传输的数据库的结果集怎么办?是被抛弃

还是被放到一个地方,等线程A恢复运行后再取出进行处理?


希望大家讨论一下这个过程,谢谢!
  • 写回答

2条回答 默认 最新

  • luxixi3600 2010-10-12 13:50
    关注

    A被咔嚓,传输的继续传输,
    B开始读取,读到哪算哪。
    都传输完了,B就能都读到,传输不完,B就只能读到存储区里面的已有数据。

    单例,线程同步,加锁,等等方法都能解决。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 ansys fluent计算闪退
  • ¥15 有关wireshark抓包的问题
  • ¥15 需要写计算过程,不要写代码,求解答,数据都在图上
  • ¥15 向数据表用newid方式插入GUID问题
  • ¥15 multisim电路设计
  • ¥20 用keil,写代码解决两个问题,用库函数
  • ¥50 ID中开关量采样信号通道、以及程序流程的设计
  • ¥15 U-Mamba/nnunetv2固定随机数种子
  • ¥15 vba使用jmail发送邮件正文里面怎么加图片
  • ¥15 vb6.0如何向数据库中添加自动生成的字段数据。