【附代码】Python 静态变量的实现方法(可多线程)

文章目录

作者:小猪快跑

基础数学&计算数学,从事优化领域6年+,主要研究方向:MIP求解器、整数规划、随机规划、智能优化算法

静态变量(Static Variable)在计算机编程领域指在程序执行前系统就为之静态分配(也即在运行时中不再改变分配情况)存储空间的一类变量。与之相对应的是在运行时只暂时存在的自动变量(即局部变量)与以动态分配方式获取存储空间的一些对象,其中自动变量的存储空间在调用栈上分配与释放。

Python 并没有静态变量,但我们可以通过一些技巧来实现这样的效果。

如有错误,欢迎指正。如有更好的算法,也欢迎交流!!!------@小猪快跑

类变量

我们先来看一个例子,容易发现类的成员变量就类似静态变量,但实例化后的成员变量就不是了。操作类的成员变量会影响实例化后成员变量,反之不会。

如果使用多线程,也没问题。

python 复制代码
import threading


class Foo:
    a = 0

    @staticmethod
    def increment():
        Foo.a += 1


if __name__ == '__main__':
    print('===== start =====')
    print("Foo().a:", Foo().a)
    print("Foo.a:", Foo.a)

    print('===== Foo.a += 1 =====')
    Foo.a += 1
    print("Foo().a:", Foo().a)
    print("Foo.a:", Foo.a)

    print('===== foo.a += 1 =====')
    foo = Foo()
    foo.a += 1
    print("foo.a:", foo.a)
    print("Foo().a:", Foo().a)
    print("Foo.a:", Foo.a)

    print('===== 10 threads foo.a += 1 =====')
    threads = [threading.Thread(target=Foo.increment) for i in range(10)]
    for t in threads:
        t.start()
    for t in threads:
        t.join()
    print("Foo.a:", Foo.a)
bash 复制代码
===== start =====
Foo().a: 0
Foo.a: 0
===== Foo.a += 1 =====
Foo().a: 1
Foo.a: 1
===== foo.a += 1 =====
foo.a: 2
Foo().a: 1
Foo.a: 1
===== 10 threads foo.a += 1 =====
Foo.a: 11

单例模式

单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场。

下面的例子希望读者要注意的是,虽然单例模式只有一个实例存在,但实例的成员变量和类成员变量并不指向同一个变量

如果使用多线程,也没问题。

python 复制代码
import threading


class Singleton:
    _instance_lock = threading.Lock()
    count = 0

    def __init__(self):
        pass

    def __new__(cls, *args, **kwargs):
        if not hasattr(Singleton, "_instance"):
            with Singleton._instance_lock:
                if not hasattr(Singleton, "_instance"):
                    Singleton._instance = object.__new__(cls)
        return Singleton._instance


def increment():
    Singleton().count += 1


if __name__ == '__main__':
    Singleton().count = 1
    Singleton().count += 2
    print(Singleton().count)  # 3
    print(Singleton.count)  # 0

    threads = [threading.Thread(target=increment) for i in range(10)]
    for t in threads:
        t.start()
    for t in threads:
        t.join()
    print(Singleton().count)  # 13
相关推荐
RainbowJie13 分钟前
Gemini CLI 与 MCP 服务器:释放本地工具的强大潜力
java·服务器·spring boot·后端·python·单元测试·maven
工作碎碎念4 分钟前
NumPy------数值计算
python
工作碎碎念12 分钟前
pandas
python
毕设源码尹学长34 分钟前
计算机毕业设计 java 血液中心服务系统 基于 Java 的血液管理平台Java 开发的血液服务系统
java·开发语言·课程设计
A7bert7771 小时前
【YOLOv5部署至RK3588】模型训练→转换RKNN→开发板部署
c++·人工智能·python·深度学习·yolo·目标检测·机器学习
lumi.1 小时前
2.3零基础玩转uni-app轮播图:从入门到精通 (咸虾米总结)
java·开发语言·前端·vue.js·微信小程序·uni-app·vue
冷月半明1 小时前
时间序列篇:Prophet负责优雅,LightGBM负责杀疯
python·算法
oioihoii1 小时前
现代C++工具链实战:CMake + Conan + vcpkg依赖管理
开发语言·c++
m0_480502641 小时前
Rust 入门 注释和文档之 cargo doc (二十三)
开发语言·后端·rust
黑客影儿1 小时前
使用UE5开发2.5D开放世界战略养成类游戏的硬件配置指南
开发语言·c++·人工智能·游戏·智能手机·ue5·游戏引擎