【附代码】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
相关推荐
Java后端的Ai之路2 小时前
【Python 教程15】-Python和Web
python
冬奇Lab3 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
灰子学技术5 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰5 小时前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码5 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚5 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂5 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1366 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
琹箐6 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
前端摸鱼匠6 小时前
YOLOv8 环境配置全攻略:Python、PyTorch 与 CUDA 的和谐共生
人工智能·pytorch·python·yolo·目标检测