为什么多线程读写 shared
1个回答
展开全部
电脑上的所有数据不管是在网络中也好,数据库也好它们流向的共同特点是只有俩种走向方式:串行与并行。那么问题来了,为什么会有俩种方式呢?
如果数据单单只是串行的话,那么不会有多线程这个概念的诞生,因为请求是一个一个执行,不会一起混在一块,比如楼主说的读写,读的请求来了先执行读,不允许写,写的请求来了先执行写,不允许读,那么就不会shared。
但是这样的方式太慢了,会造成大量的请求不能及时处理,拥堵在了一起,于是,人们发现必须要并行处理,即必要的时候请求一起执行,这样的话效率是高了,但出错率也大大提升。
至于楼主问道为什么要shared,我认为既然要效率读写肯定要shared,否则就和多线程没有关系了,只要合理的控制出错的可能行,多线程一定会给你带来惊喜!
如果数据单单只是串行的话,那么不会有多线程这个概念的诞生,因为请求是一个一个执行,不会一起混在一块,比如楼主说的读写,读的请求来了先执行读,不允许写,写的请求来了先执行写,不允许读,那么就不会shared。
但是这样的方式太慢了,会造成大量的请求不能及时处理,拥堵在了一起,于是,人们发现必须要并行处理,即必要的时候请求一起执行,这样的话效率是高了,但出错率也大大提升。
至于楼主问道为什么要shared,我认为既然要效率读写肯定要shared,否则就和多线程没有关系了,只要合理的控制出错的可能行,多线程一定会给你带来惊喜!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询