线程记录(1)

创建线程:

一、1.继承Thread,重写run(),将操作写入其中

        2.创建子类对象,start()

二、1.实现runnable接口,实现run()

        2.创建子类对象,将子类对象作为参数传递到thread的构造器中,创建出Thread类的对象

        3.Thread类的对象调用start()

作用:实现runnable接口,没有单继承的局限性,更适合处理多个线程有共享数据的情况。

三、1.实现Callable接口,实现call(),将操作写入其中,

        2.创建实现callable接口的对象,作为参数传递到FutureTask对象中,

        3.将FutureTask对象作为参数传递到Thread对象,调用start()

        4.获取Callable中call方法的返回值

作用:

四、1.以方式二、三创建好runnable接口或callable的实现类,重写run()或call()

        2.创建线程池

        3.调用execute()执行某个线程,参数就是实现类

作用:

1.提高了响应速度(减少了创建新线程时间)

2.降低资源消耗(重复利用线程池中的线程,不需要每次都创建)

3.便于线程管理

五、匿名类:再thread对象中,将参数作为一个方法,new一个runnable(),重写run()

run()和start():
run()中包含要执行的线程内容,当run()方法运行结束后,线程随即终止。

start()启动线程,调用start0()进行系统调度资源分配。

直接调用run():相当于调用一个普通方法,并没有启动一个线程。

调用start():线程会进入就绪状态并得到cpu时间片后开始执行run()方法中的任务。

runnable和Callable:

Callable的 call() 方法可以返回值和抛出异常,Callable可以返回装载有计算结果的Future对象。runnable不能

                

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Python 中,可以使用 `logging` 模块记录日志。如果需要在多线程环境下记录日志,可以使用 `concurrent_log_handler` 模块来实现。 首先需要安装 `concurrent_log_handler` 模块: ``` pip install concurrent_log_handler ``` 然后,可以使用以下代码来记录日志: ```python import logging from concurrent_log_handler import ConcurrentRotatingFileHandler import threading # 创建日志记录器 logger = logging.getLogger(__name__) logger.setLevel(logging.DEBUG) # 创建文件处理器 handler = ConcurrentRotatingFileHandler(filename='example.log', mode='a', maxBytes=1024, backupCount=3) handler.setLevel(logging.DEBUG) formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s') handler.setFormatter(formatter) # 将处理器添加到记录器 logger.addHandler(handler) # 多线程记录日志 def worker(): logger.debug('Debug message from thread {0}'.format(threading.current_thread().name)) logger.info('Info message from thread {0}'.format(threading.current_thread().name)) logger.warning('Warning message from thread {0}'.format(threading.current_thread().name)) logger.error('Error message from thread {0}'.format(threading.current_thread().name)) logger.critical('Critical message from thread {0}'.format(threading.current_thread().name)) threads = [] for i in range(10): t = threading.Thread(target=worker) threads.append(t) t.start() for t in threads: t.join() ``` 上面的代码中,创建了一个 `ConcurrentRotatingFileHandler` 类实例化的文件处理器,它可以在多线程环境下安全地写入日志文件。然后,将处理器添加到日志记录器中,并使用多线程记录日志。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值