Flask—上下文

本文探讨了Flask框架的上下文管理机制,包括线程安全的概念,介绍了threadding.local方法确保线程间数据独立。Flask的上下文分为请求上下文和应用上下文,使用LocalStack实现线程隔离,确保不同请求之间的数据不互相影响。
摘要由CSDN通过智能技术生成

一、线程安全

1. 定义

        在多线程中,同一个进程中的多个线程是共享一个内存地址的,多个线程操作数据时,就会造成数据的不安全,所有我们就要加锁。但是对于一些变量,如果仅仅只在本线程中使用,怎么办?

        方法1:可以通过全局的字典,key为当前线程的线程ID,value为具体的值。

        方法2:使用threadding.local方法

2. threadding.local方法

        threading.local在多线程操作时,为每一个线程创建一个值,使得线程之间各自操作自己的值,互不影响。

from threading import local
import time

class Foo(local):
    pass

foo = Foo()
foo.num = 1

def my_num(i):
    foo.num = i
    # time.sleep(1)
    print(foo.num, threading.current_thread().ident)

for i in range(10):
    th = threading.Thread(target=my_num,args=(i,))
    th.start()

 

3. 栈

class MyStack(object):
    data = []

    def __setattr__(self, key, value):
        self.push(key,value)

    def push(s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值