'''方式一:线程池的方式'''
# from   concurrent.futures  import   ThreadPoolExecutor
# import   requests
# import  time
#
#
# def  task(url):
#     response=requests.get(url)
#     print(url,response)
#
#
# pool=ThreadPoolExecutor(7)
#
#
# url_list=[
#     'http://www.baidu.com',
#     'http://www.baidu.com',
#     'http://www.baidu.com',
#     'http://www.baidu.com',
# ]
#
#
# for  url   in  url_list:
#     pool.submit(task,url)
# pool.shutdown(wait=True)
'''编写方式二'''
from   concurrent.futures  import   ThreadPoolExecutor,ProcessPoolExecutor##前面是多线程,后面是多进程
import   requests
import  time
'''(url,response)当返回一个参数的时候,就会被当做一个整体进行返回,就是一个参数'''
def  task(url):
    '''下载页面'''
    response=requests.get(url)
    # print(url,response)
    # return   (url,response)##在这里进行返回值回去,当有返回值的时候,在下面的return_obj里面可以被接收到,就可以打印出来
    return response##在这里进行返回值回去,当有返回值的时候,在下面的return_obj里面可以被接收到,就可以打印出来
'''arg是放列表和字典的 '''
def  done(return_obj,*args,**kwargs):
    response=return_obj.result()
    # print(response)
    print(response.status_code)###返回状态码
    # print(response.content)
    # print(args)
    # print(kwargs)
pool=ThreadPoolExecutor(7)
url_list=[
    'http://www.baidu.com',
    'http://www.baidu.com',
    'http://www.baidu.com',
    'http://www.baidu.com',
]
for  url   in  url_list:
    v=pool.submit(task,url)
    v.add_done_callback(done)##当执行完上面的程序的时候,就会自动执行回调函数
pool.shutdown(wait=True)