day35-python之協程

1.協程python

# import time
# import queue
#
# def consumer(name):
#
#     print("--->ready to eat baozi...")
#     while True:
#         new_baozi = yield
#         print("[%s] is eating baozi %s" % (name,new_baozi))
#         #time.sleep(1)

# def producer():
#
#     r = con.__next__()
# #     r = con2.__next__()
# #
# #     n = 0
# #     while 1:
# #         time.sleep(1)
# #         print("\033[32;1m[producer]\033[0m is making baozi %s and %s" %(n,n+1) )
# #         con.send(n)
# #         con2.send(n+1)
# #         n +=2
# #
# #
# # if __name__ == '__main__':
# #
# #     con = consumer("c1")
# #     con2 = consumer("c2")
# #     producer()


# from greenlet import greenlet
#
# def test1():
#     print(12)
#     gr2.switch()
#     print(34)
# def test2():
#     print(56)
#     gr1.switch()
#     print(78)
#     gr1.switch()
#
# gr1 = greenlet(test1)
# gr2 = greenlet(test2)
# gr2.switch()


# import gevent
# import requests,time
# start=time.time()
# def f(url):
#     print('GET: %s' % url)
#     resp =requests.get(url)
#     data = resp.text
#     print('%d bytes received from %s.' % (len(data), url))
#
# f('https://www.python.org/')
# f('https://www.yahoo.com/')
# f('https://www.baidu.com/')
# f('https://www.sina.com.cn/')
# f("http://www.xiaohuar.com/hua/")
#
# # gevent.joinall([
# #         gevent.spawn(f, 'https://www.python.org/'),
# #         gevent.spawn(f, 'https://www.yahoo.com/'),
# #         gevent.spawn(f, 'https://www.baidu.com/'),
# #         gevent.spawn(f, 'https://www.sina.com.cn/'),
# #         gevent.spawn(f, 'http://www.xiaohuar.com/hua/'),
# # ])
#
# # f('https://www.python.org/')
# #
# # f('https://www.yahoo.com/')
# #
# # f('https://baidu.com/')
#
# # f('https://www.sina.com.cn/')
#
# print("cost time:",time.time()-start)

2.進程同步app

# from multiprocessing import Process, Lock
# import time
#
 
# def f(l, i):
#
#         l.acquire()
#         time.sleep(1)
#         print('hello world %s' % i)
#         l.release()
#
# if __name__ == '__main__':
#     lock = Lock()
#
#     for num in range(10):
#         Process(target=f, args=(lock, num)).start()

3.進程池async

# from  multiprocessing import Process,Pool
# import time,os
#
# def Foo(i):
# 
#     time.sleep(1)
#     print(i)
#     print("son",os.getpid())
#
#     return "HELLO %s"%i
#
from multiprocessing import  Process,Pool
# def Bar(arg):
#     print(arg)
#     # print("hello")
#     # print("Bar:",os.getpid())
#
# if __name__ == '__main__':
#
#     pool = Pool(5)
#     print("main pid",os.getpid())
#     for i in range(100):
#         #pool.apply(func=Foo, args=(i,))  #同步接口
#         #pool.apply_async(func=Foo, args=(i,))
#
#         #回調函數:  就是某個動做或者函數執行成功後再去執行的函數
#
#         pool.apply_async(func=Foo, args=(i,),callback=Bar)
#
#     pool.close()
#     pool.join()         # join與close調用順序是固定的
#
#     print('end')

4.進程通訊函數

#
#
#
# import queue,time
#
# import multiprocessing
# def foo(q):
#     time.sleep(1)
#     print("son process",id(q))
#     q.put(123)
#     q.put("yuan")
#

# if __name__ == '__main__':
#     #q=queue.Queue()
#     q=multiprocessing.Queue()
#     p=multiprocessing.Process(target=foo,args=(q,))
#     p.start()
#     #p.join()
#     print("main process",id(q))
#     print(q.get())
#     print(q.get())
#
#
#
#
#
#
# from multiprocessing import Process, Pipe
# def f(conn):
#     conn.send([12, {"name":"yuan"}, 'hello'])
#     response=conn.recv()
#     print("response",response)
#     conn.close()
#     print("q_ID2:",id(conn))
#

# if __name__ == '__main__':
#
#     parent_conn, child_conn = Pipe() #雙向管道
#
#     print("q_ID1:",id(child_conn))
#     p = Process(target=f, args=(child_conn,))
#     p.start()
#
#     print(parent_conn.recv())   # prints "[42, None, 'hello']"
#     parent_conn.send("兒子你好!")
#     p.join()
#
#
# from multiprocessing import Process, Manager
#
# def f(d, l,n):
#
#     d[n] = '1'    #{0:"1"}
#     d['2'] = 2    #{0:"1","2":2}
#
#     l.append(n)    #[0,1,2,3,4,   0,1,2,3,4,5,6,7,8,9]
#     #print(l)
#
 
# if __name__ == '__main__':
#
#     with Manager() as manager:
#
#         d = manager.dict()#{}
#
#         l = manager.list(range(5))#[0,1,2,3,4]
#
#
#         p_list = []
#
#         for i in range(10):
#             p = Process(target=f, args=(d,l,i))
#             p.start()
#             p_list.append(p)
#
#         for res in p_list:
#             res.join()
#
#         print(d)
#         print(l)
相關文章
相關標籤/搜索