day20-多线程

一、多线程

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

程序员自己创建的线程叫子线程。

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

多个线程的任务同时执行。

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

1.创建一个线程对象

Thread(target=, args=)
target:需要传一个需要在子线程中执行的函数(类型是function的变量)
args:在子线程中调用target对应的函数的时候,该传什么参数,类型是元组。
t1 = threading.Thread(target=download, args=('阿Q正传',))


2.在子线程中去执行任务

t1.start()

代码

import time
import datetime
import random
import threading


def download(file):
    # current_thread()获取当前线程
    print(file, threading.current_thread())
    print(datetime.datetime.now(), '开始下载:%s' % file)

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

if __name__ == '__main__':

    # 1.创建一个线程对象
    t1 = threading.Thread(target=download, args=('阿Q正传',))
    t2 = threading.Thread(target=download, args=('肖生克的救赎',))

    # 2.在子线程中去执行任务
    t1.start()
    t2.start()

测试结果

1.PNG

二、创建线程2

1.创建线程方式1

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


2.创建线程方式2

a.写一个自己的类去继承Thread类。
b.重写当前类的run方法,run方法中的任务就是在子线程中执行的任务。
c.创建当前类的对象,就是线程对象。然后调用start去执行线程中的任务。
注意:如果直接调用run方法,run方法中的任务不会在当前的子线程中执行,而是直接在主线程中执行。

代码

from threading import Thread, current_thread
import time
from datetime import datetime


# 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('肖生克的救赎')
# 3.通过start方法去执行run中的任务
"""
注意:如果直接调用run方法,run方法中的任务不会在当前的子线程中执行,而是直接在主线程中执行。
"""
# t1.run()
t1.start()
t2.start()

测试结果

2.PNG

三、server

代码

import socket
from threading import Thread


class ConversationThread(Thread):
    def __init__(self, conversation: socket, addr):
        super().__init__()
        self.conversation = conversation
        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.conversation.send(message.encode('utf-8'))


def creat_server():
    server = socket.socket()
    server.bind(('10.7.156.121', 8080))
    server.listen(512)

    while True:
        # 会阻塞线程
        conversation, addr = server.accept()

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

if __name__ == '__main__':
    creat_server()

测试结果

3.PNG

四、client

代码

import socket

client = socket.socket()
client.connect(('10.7.156.121', 8080))

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

    message_re = client.recv(1024).decode('utf-8')
    print(message_re)

测试结果

4.PNG

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 进程和线程 进程 所有运行中的任务通常对应一个进程,当一个程序进入内存运行时,即变成一个进程.进程是处于运行过程中...
    胜浩_ae28阅读 5,245评论 0 23
  • 线程 操作系统线程理论 线程概念的引入背景 进程 之前我们已经了解了操作系统中进程的概念,程序并不能单独运行,只有...
    go以恒阅读 1,769评论 0 6
  • 一文读懂Python多线程 1、线程和进程 计算机的核心是CPU,它承担了所有的计算任务。它就像一座工厂,时刻在运...
    星丶雲阅读 1,562评论 0 4
  • Java多线程学习 [-] 一扩展javalangThread类 二实现javalangRunnable接口 三T...
    影驰阅读 3,089评论 1 18
  • 文|汝之尾巴草 -01- 舅舅家里终于买了房子,全家人都很开心,除了她一个人。 房子虽然不在市区,但交通也还算方便...
    汝之尾巴草阅读 3,725评论 48 80

友情链接更多精彩内容