只有一个线程时,线程使用完时间片会出现线程切换吗?
为什么有些人说多线程快?
为什么redis用单线程,因为单线程没有线程切换开销,会提升效率?
感觉有点矛盾啊!
哪位大神能详细讲清楚吗?
只有一个线程时,线程使用完时间片会出现线程切换吗?
为什么有些人说多线程快?
为什么redis用单线程,因为单线程没有线程切换开销,会提升效率?
感觉有点矛盾啊!
哪位大神能详细讲清楚吗?
说什么也是单线程快,但为什么会有多线程呢,那是因为现在的很多场景都是多任务要同时进行,比如要同时写某一个文件的同时还要接收网络数据,但是很多系统调用不会马上有结果,就需要先把当前任务暂停,让系统先去处理其它任务,这个时候就多线程来说是比单线程串联执行完多个任务的总体时间要短的,但线程切换是有性能损耗的,但是这点性能损耗对整体来说可以忽略不计,但随着线程数越来越多的话这种损耗就相当可观了,导致系统处理上下文切换的时间越来越长。 redis是纯内存操作,所以用单线程是很快的,也不要考虑并发问题,但是redis也会有数据的持久化操作,也会fork线程进行数据的持久化