python中主线程类给子线程类共享数据,py文件之间共享数据

1 主线程类和子线程类是不同的 Python 文件,使用共同的模块来定义共享变量 stock_price
stock_price = None
2 在主线程的文件 main.py 中导入共同的模块,并使用 data.stock_price 引用共享变量
import time
import threading
import data

# 获取股票价格的函数
def get_stock_price():
    # 调用第三方 API 获取股票价格
    price = api.get_price()
    # 更新共享变量
    data.stock_price = price

# 主线程类
class MainThread:
    def __init__(self):
        # 启动子线程
        self.threads = []
        for i in range(4):
            t = ProcessThread()
            self.threads.append(t)
            t.start()
    def run(self):
        # 每秒钟获取一次股票价格并更新共享变量
        while True:
            get_stock_price()
            print("Price updated: ", data.stock_price)
            time.sleep(1)

if __name__ == "__main__":
    main_thread = MainThread()
    main_thread.run()
3 在子线程的文件 process.py 中也需要导入共同的模块,并使用 data.stock_price 引用共享变量
import time
import threading
import data

# 子线程类
class ProcessThread(threading.Thread):
    def run(self):
        while True:
            # 从共享变量中读取股票价格
            price = data.stock_price
            # 进行处理
            print("Price processed: ", price)
            time.sleep(0.1)  # 模拟处理耗时
4 总之, 主线程操作数据模块中的数据, 子线程使用模块中的数据

你可能感兴趣的:(python基础,python,开发语言)