python multi-threading slower than serial?

前端 未结 3 1617
别跟我提以往
别跟我提以往 2020-11-30 11:18

I\'m trying to figure out multi-threading programming in python. Here\'s the simple task with which I want to compare serial and parallel speeds.

import thr         


        
3条回答
  •  星月不相逢
    2020-11-30 11:49

    Other answers have referred to the issue of the GIL being the problem in cpython. But I felt there was a bit of missing information. This will cause you performance issues in situations where the code you are running in threads is CPU bound. In your case here, yes doing many calculations in threads is going to most likely result in dramatically degraded performance.

    But, if you were doing something that was more IO bound, such as reading from many sockets in a network application, or calling out to subprocess, you can get performance increases from threads. A simple example for your code above would be to add a stupidly simple call out to the shell:

    import os
    
    def sinFunc(offset, n):
      result = []
      for i in xrange(n):
        result.append(math.sin(offset + i * i))
      os.system("echo 'could be a database query' >> /dev/null; sleep .1")
      return result
    

    That call might have been something real like waiting on the filesystem. But you can see that in this example, threading will start to prove beneficial, as the GIL can be released when the thread is waiting on IO and other threads will continue to process. Even so, there is still a sweet spot for when more threads start to become negated by the overhead of creating them and synchronizing them.

    For CPU bound code, you would make use of multiprocessing

    From article: http://www.informit.com/articles/article.aspx?p=1850445&seqNum=9

    ...threading is more appropriate for I/O-bound applications (I/O releases the GIL, allowing for more concurrency)...

    Similar question references about threads vs processes:
    https://stackoverflow.com/a/1227204/496445
    https://stackoverflow.com/a/990436/496445

提交回复
热议问题