内容回顾

单列模式实现的多种方式

# 方式一:定义一个类实现单例模式
class C1:
__instance = None
def __init__(self,name, age):
self.name = name
self.age = age @classmethod # 运用了类的绑定
def singlethon(cls):
if not cls.__instance:
cls.__instance = cls('jason', 18)
return cls.__instance
obj = C1.singlethon()
print(obj.name) # jason
obj1 = C1.singlethon()
print(obj1.name) # jason
obj3 = C1('kevin', 28)
print(obj3.name) # kevin
# 方式二:定制元类实现单例模式
class Mymeta(type):
def __init__(cls, what, bases=None, dict=None): # 产生类的时候调用
# 事先从配置文件中去配置来造一个Mysql的实例出来
cls.__instance = cls.__new__(cls) # 产生对象
cls.__init__(cls.__instance, 'jason', 18) # 初始化对象
# 上述两步可以合成下面一步
# slef.__instance = super().__call__(*args, **kwargs)
super().__init__(what, bases, dic) def __call__(cls, *args, **kwargs): # 如果调用类加括号 括号里面有值走这
if args or kwargs:
obj = cls.__new__(cls)
cls.__init__(obj, *args, **kwargs)
return obj
return cls.__instance # 括号里面没有值 直接将产生的时候定义好的对象返回赋值 这样保证类加括号没值调用的时候 返回的永远都是同一个对象 class Mysql(metaclass=Mymeta):
def __init__(self, name, age):
self.name = name
self.age = age obj1 = Mysql()
obj2 = Mysql()
print(obj1.name) # jason
print(obj2.name) # jason
obj3 = Mysql('tony', 18)
print(obj3.name) # tony
# 方式三:基于模块的单例模式:提前产生一个对象 之后导模块使用
class C1:
def __init__(self, name):
self.name = name
obj = C1('jason') # 提前定义好 之后再通过到模块的方式通过对象obj去调
# 方式四:基于装饰器的单例模式
class C1:
def __init__(self, name):
self.name = name obj = C1('jason') def outer(cls):
_instance = cls('jason', 18)
def inner(*args, **kwargs):
if args or kwargs:
obj = cls(*args, **kwargs)
return obj
return _instance
return inner @outer # Mysql = outer(Mysql)
class Mysql:
def __init__(self, host, port):
self.host = host
self.port = port

​ 总结:单例模式想要实现的话 提前先让类产生一个对象 再提前去存放好 当类加括号实例化对象的时候去判断对象有无传参来判断是要产生新的对象还是用提前存放好的单例模式

pickle序列化模块

优势:能够序列化python中所有的类型

缺陷:只能够在python中使用 无法跨语言传输

需求:产生一个对象并保存到文件中 取出来还是一个对象

# 只能是二进制模式 且不能跨文件 得跟类体代码一起
class C1:
def __init__(self, name, age):
self.name = name
self.age = age def func1(self):
print('from func1') def func2(self):
print('from func2') obj = C1('jason', 18) import pickle
with open(r'a.txt', 'wb') as f:
pickle.dump(obj, f) with open(r'a.txt', 'rb') as f:
res = pickle.load(f) # 其中要注意的是,在load(file)的时候,要让python能够找到类的定义,否则会报错
res.func1()
print(res.name)

根据类名或对象名如何获取到类的字符串名

选课系统需求分析

选课系统
角色:学校、学员、课程、讲师
要求:
1. 创建北京、上海 2 所学校
2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上海开
3. 课程包含,周期,价格,通过学校创建课程
4. 通过学校创建班级, 班级关联课程、讲师5. 创建学员时,选择学校,关联班级
5. 创建讲师角色时要关联学校,
6. 提供三个角色接口
6.1 学员视图, 可以注册, 交学费, 选择班级,
6.2 讲师视图, 讲师可管理自己的班级, 上课时选择班级, 查看班级学员列表 , 修改所管理的学员的成绩
6.3 管理视图,创建讲师, 创建班级,创建课程
7. 上面的操作产生的数据都通过pickle序列化保存到文件里

功能提炼

1.管理员功能
注册功能
登录功能
创建学校
创建课程
创建老师
2.讲师功能
登入功能
选择课程
查看课程
查看学生分数
修改学生分数
3.学生功能
注册功能
登入功能
选择学校
选择课程
查看课程分数

选课系统架构设计

三层架构
1.第一层展示及用户简单的信息获取
2.第二层核心逻辑层
3.第三层数据处理层创建models.py储存所有的类 只有该文件内的代码有资格调用db_handler

选课系统目录搭建

基于软件开发目录规范即可

单例模式及pickle序列化模块的更多相关文章

  1. python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)

    1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文 ...

  2. json和pickle序列化模块

    一.json序列化模块 1.序列化:将内存数据转成字符串加以保存. 2.反序列化:将字符串转成内存数据加以读取. data = { '北京':{ '五道口':{ 'sohu':'引擎', } } } ...

  3. (转)python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)

    阅读目录 1.1.1导入模块 1.1.2__name__ 1.1模块 什么是模块: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代 ...

  4. day14-Python运维开发基础(内置函数、pickle序列化模块、math数学模块)

    1. 内置函数 # ### 内置函数 # abs 绝对值函数 res = abs(-10) print(res) # round 四舍五入 (n.5 n为偶数则舍去 n.5 n为奇数,则进一!) 奇进 ...

  5. (1)json和pickle序列化模块

    json 和pickle 模块 json和pickle模块下都有4个功能 dumps  <---> loads  (序列化 <--->反序列化) dump <---> ...

  6. 13、Python文件处理、os模块、json/pickle序列化模块

    一.字符编码 Python3中字符串默认为Unicode编码. str类型的数据可以编码成其他字符编码的格式,编码的结果为bytes类型. # coding:gbk x = '上' # 当程序执行时, ...

  7. python之序列化模块、双下方法(dict call new del len eq hash)和单例模式

    摘要:__new__ __del__ __call__ __len__ __eq__ __hash__ import json 序列化模块 import pickle 序列化模块 补充: 现在我们都应 ...

  8. Python 基础之序列化模块pickle与json

    一:pickle 序列化模块把不能够直接存储的数据,变得可存储就是序列化把存储好的数据,转化成原本的数据类型,加做反序列化 php: 序列化和反序列化(1)serialize(2)unserializ ...

  9. day 20 - 1 序列化模块,模块的导入

    序列化模块 首先我们来看一个序列:'sdfs45sfsgerg4454287789sfsf&*0' 序列 —— 就是字符串序列化 —— 从数据类型 --> 字符串的过程反序列化 —— 从 ...

  10. python day7: time,datetime,sys,pickle,json模块

    目录 python day 7 1. time模块 2. datetime模块 2.1 date类 2.2 time类 2.3 datetime类 2.4 timedelta类 2.5 tzinfo时 ...

随机推荐

  1. Java线程同步的四种方式详解(建议收藏)

    ​ Java线程同步属于Java多线程与并发编程的核心点,需要重点掌握,下面我就来详解Java线程同步的4种主要的实现方式@mikechen 目录 什么是线程同步 线程同步的几种方式 1.使用sync ...

  2. PAT (Basic Level) Practice 1010 一元多项式求导 分数 25

    设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为nxn−1.) 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数).数字间以空格分隔. 输出格式: ...

  3. frp服务利用云主机实现Windows远程连接

    frp服务利用云主机实现Windows远程连接 1.下载所需要的安装包 https://github.com/fatedier/frp/releases 下载 frp_0.44.0_linux_amd ...

  4. windows下利用_popen,_wpoen创建管道进行系统命令输出数据

    转载: https://blog.csdn.net/greless/article/details/72383762 参考: http://www.linuxidc.com/Linux/2011-04 ...

  5. 堆内存动态分配情况和jvm调优方向

    由上图可以看出: 堆中分为新生代(占堆1/3内存)和老年代(占堆2/3内存), 新生代又分为Eden区(占新生代内存的8/10)和survivor区(占新生代内存的2/10), survivor区又分 ...

  6. 齐博x2自建流媒体RTMP直播服务器

    这里只讲解大家最容易配置的Windows版,测试环境是2008版服务器及WIN7下载下面的软件,解压在任何目录都可,然后双击"启动.bat"即可http://down.php168 ...

  7. Abp.Zero 手机号免密登录验证与号码绑定功能的实现(一):验证码模块

    这是一篇系列博文,我将使用Abp.Zero搭建一套集成手机号免密登录验证与号码绑定功能的用户系统: Abp.Zero 手机号免密登录验证与号码绑定功能的实现(一):验证码模块 Abp.Zero 手机号 ...

  8. .net 温故知新:【8】.NET 中的配置从xml转向json

    一.配置概述 在.net framework平台中我们常见的也是最熟悉的就是.config文件作为配置,控制台桌面程序是App.config,Web就是web.config,里面的配置格式为xml格式 ...

  9. .net 温故知新:【9】.NET日志记录 ILogger使用和原理

    日志 日志作为我们程序记录的"黑匣子"是不论什么系统都会使用到的,比如我们经常使用的log4net就是第三方日志记录提供程序.NET 支持使用各种内置和第三方日志记录提供程序的日志 ...

  10. [leetcode] 706. Design HashMap

    题目 Design a HashMap without using any built-in hash table libraries. Implement the MyHashMap class: ...