day20-多线程

1.多线程

每个程序在运行的时候(进程)系统都会为这个进程创建一个线程,这个线程我们叫主线程
程序员自己创建的线程叫子线程

多个任务在一个线程中是按顺序一个一个执行的(线程的串行)

多个线程的任务同时执行

代码示例

print('abc')

import time
from random import randint
import datetime


def download(file):
    print(file, threading.current_thread())
    print(datetime.datetime.now(), '开始下载:%s' % file)
    # sleep(时间):将当前线程阻塞指定的时间(停指定的时间在往后执行)
    # 时间单位:秒
    time1 = randint(5, 10)
    time.sleep(time1)
    print(datetime.datetime.now(), '下载%s结束' % file, '总共耗时:%d' % time1)


"""
python通过threading标准库来支持多线程
"""
import threading

if __name__ == '__main__':
    # download('肖生克的救赎')
    # current_thread()获取当前线程
    print(threading.current_thread())
    # 1.创建一个线程对象
    """
    Thread(target=, args=)
    target:需要传一个需要在子线程中执行的函数(类型是function的变量)
    args:在子线程中调用target对应的函数的时候,该传什么参数。(类型是元组)
    """
    t1 = threading.Thread(target=download, args=('阿甘正传',))
    t2 = threading.Thread(target=download, args=('肖生克的救赎',))
    # 2.让子线程去执行任务
    t1.start()
    t2.start()

运行结果

<_MainThread(MainThread, started 2152)>
阿甘正传 <Thread(Thread-1, started 12008)>
2018-10-25 17:20:23.031358 开始下载:阿甘正传
肖生克的救赎 <Thread(Thread-2, started 12484)>
2018-10-25 17:20:23.031358 开始下载:肖生克的救赎
2018-10-25 17:20:31.032246 下载阿甘正传结束 总共耗时:8
2018-10-25 17:20:33.032749 下载肖生克的救赎结束 总共耗时:10

2.创建线程

创建线程方式1:
直接通过Thread类创建对象,将需要在子线程中执行的函数作为target参数传进去

创建线程方式2:
a.写一个自己的类去继承Thread类
b.实现当前类的run方法,run中的任务就是在子线程中执行的任务
c.创建当前类的对象,就是线程对象。然后调用start去执行线程中的任务

代码示例

from threading import Thread,current_thread
from datetime import datetime
import time
# 1.创建线程类
class DownLoadThread(Thread):
    """下载线程类"""
    def __init__(self, file):
        super().__init__()
        self.file = file

    def run(self):
        # 注意:如果需要给run方法中传数据,通过当前类的属性传
        print('%s开始下载:' % self.file, datetime.now())
        time.sleep(5)
        print('%s下载完成:' % self.file, datetime.now())


# 2.创建线程对象
t1 = DownLoadThread('阿甘正传')
t2 = DownLoadThread('阿Q正传')
# 3.通过start去执行run中的任务
"""
注意:如果直接调用run方法,run方法中的任务不会在当前子线程中执行
"""
t1.start()
t2.start()

运行结果

阿甘正传开始下载: 2018-10-25 17:22:37.675023
阿Q正传开始下载: 2018-10-25 17:22:37.675985
阿甘正传下载完成: 2018-10-25 17:22:42.676061
阿Q正传下载完成: 2018-10-25 17:22:42.676061

4.应用

  • server(服务端)

代码示例

import socket
from threading import Thread


class ConversationThread(Thread):
    def __init__(self, coversation: socket.socket, addr):
        super().__init__()
        self.conversation = coversation
        self.addr = addr

    def run(self):
        while True:
            # 接收消息
            message_re = self.conversation.recv(1024).decode('utf-8')
            print(self.addr[0], ':', message_re)

            message = 'hi %s ,你好!' % self.addr[0]
            self.conversion.send(message.encode('utf-8'))


def creat_server():
    server = socket.socket()
    server.bind(('10.7.156.96', 8086))
    server.listen(512)

    # 让服务器一直运行
    while True:
        # 阻塞线程
        conversion, addr = server.accept()

        # 创建处理这个请求对应的子线程
        t = ConversationThread(conversion, addr)
        t.start()


if __name__ == '__main__':
    creat_server()
  • client

代码示例

import socket

client = socket.socket()
client.connect(('10.1.156.96', 8083))

while True:
    message_re = client.recv(1024).decode('utf-8')
    print(message)

    message = input('>>>')
    client.send(message.encode('utf-8'))

运行结果可自行测试

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,009评论 19 139
  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,655评论 8 265
  • 菜鸟实验中 ing........(自定义管道) 第一步:创建一个文件夹,专门用于写pipe的,名字随意 第二步:...
    月半女那阅读 576评论 0 1
  • 网络基础 端口号范围0-65535,系统保留0-1023,常见端口http:80,ftp:21,telnet:23...
    有苦向瓜诉说阅读 662评论 0 2
  • 4.4 赋值运算符 赋值运算符的左侧运算对象必须是一个可修改的左值 位运算符 后置递增运算符的优先级高于解引用运算...
    HenryTien阅读 837评论 0 0