摘要: 协程 1,定义: 协程:是单线程下的并发,又称微线程,纤程 协程是一种用户态的轻量级线程,即协程是由用户程序自己控制调度的 python的线程属于内核级别的,即由操作系统控制调度,如果单线程遇到IO阻塞或者长时间CPU就会且走,执行其他程序 单线程开启协程,一旦遇到IO阻塞,就会从应用程序级别控制切 阅读全文
posted @ 2019-12-13 12:23 阿浪阿浪 阅读(158) 评论(0) 推荐(0)
摘要: Even事件 1,定义 同进程的一样 ,线程的一个关键特性是每个线程都是独立运行且状态不可预测。如果程序中的其 他线程需要通过判断某个线程的状态来确定自己下一步的操作,这时线程同步问题就会变得非常棘手。为了解决这些问题,我们需要使用threading库中的Event对象。 对象包含一个可由线程设置的 阅读全文
posted @ 2019-12-13 12:21 阿浪阿浪 阅读(191) 评论(0) 推荐(0)
摘要: 1,堆栈结构 后进先出的队列 栈结构:其实就是一个后进先出的一个线性表,只能在栈顶压入或弹出元素 如何用列表实现栈 2,队列 队列,类似于栈 队列,其实就是一个先进先出的线性表,只能在队首执行删除操作,在队尾执行插入操作,用列表表示队列,可以用append()方法实现队尾插入元素,用pop(0)方法 阅读全文
posted @ 2019-12-13 12:19 阿浪阿浪 阅读(136) 评论(0) 推荐(0)
摘要: 同步异步 1,同步 同步是指一个进程在执行某个请求的时候,若该请求需要一段时间才能返回信息,那个这个进程会一直等待下去,直到收到返回信息,才继续执行下去 2,异步 是指进程不需要一直等待下去,而是继续执行下面的操作,不管其他进程 的状态,当有消息返回时系统会通知进程进行处理,这样可以提高执行的效率 阅读全文
posted @ 2019-12-13 12:17 阿浪阿浪 阅读(144) 评论(0) 推荐(0)
摘要: 多线程 1,GIL全局解释器锁 1. python GIL:(Global Interpret Lock)全局解释器锁 2. CPython解释器自动加载GIL锁,基于单核CPU的GIL锁,为了保证数据的安全,单个进程的多线程不能利用多核,即可以并发,但是不能并行,多个进程可以并发,并行 3. JP 阅读全文
posted @ 2019-12-13 12:13 阿浪阿浪 阅读(188) 评论(0) 推荐(0)
摘要: 死锁现象与递归锁 1. 死锁: 是指两个或两个以上的进程或线程在执行过程中,因为争夺资源而造成的一种互相等待的现象,若无外力作用,他们都将无法推进下去,此时系统处于死锁状态或系统产生了死锁,这些永远在等待的进程称为死锁进程 2. 递归锁 1. 解决死锁现象的方法:就是递归锁 2. 同一把锁,引用一次 阅读全文
posted @ 2019-12-13 12:11 阿浪阿浪 阅读(117) 评论(0) 推荐(0)
摘要: 线程 1,生产者消费者模型 1. 什么是生产者与消费者模型 生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题,生产者和消费者之间不直接通讯,而通过阻塞队列来通讯,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力 在并发编程中使用生产者和消费者模式能够解决大多数并发问题,该模式 阅读全文
posted @ 2019-12-13 12:08 阿浪阿浪 阅读(390) 评论(0) 推荐(0)
摘要: 互斥锁 锁:from multiprocessing import Lock,Lock即为锁 lock与join的区别 共同点:都可以把并发变成串行,保证了顺序 不同点:join人为设定顺序,lock让其争抢顺序,保证了公平性 进程之间的通信 1,基于文件通信 效率低 应用到了互斥锁:可以公平性的保 阅读全文
posted @ 2019-12-13 12:04 阿浪阿浪 阅读(182) 评论(0) 推荐(0)
摘要: 多进程 1, multiprocessing模块介绍 multiprocessing模块用来开启子进程,并在子进程中执行我们定制的任务(比如函数),该模块与多线程模块threading的编程接口类似。 multiprocessing模块的功能众多:支持子进程、通信和共享数据、执行不同形式的同步,提供 阅读全文
posted @ 2019-12-13 12:02 阿浪阿浪 阅读(190) 评论(0) 推荐(0)
摘要: 进程 1,进程的基础 1. 程序 一堆静态的代码文件 2. 进程 一个正在运行的程序进程,抽象的概念 由操作系统操控调用与CPU运行 3. 操作系统 1. 管理控制协调计算机中硬件与软件的关系 2. 作用 1. 将一些对硬件操作的复杂丑陋的接口,变成简单美丽的接口 2. 多个进程抢占一个CPU时资源 阅读全文
posted @ 2019-12-13 11:51 阿浪阿浪 阅读(125) 评论(0) 推荐(0)
摘要: socket 1,定义 1. 套接字 1. 基于tcp协议 2. socket是基于应用层与传输层之间的抽象层,是一组操作起来非常简单的接口,接收应用层的数据,然后传给操作系统 2. 分类: 1. 基于文件类型的套接字家族:AF UNIX,不常用 2. 基于网络类型的套接字家族:AF INET 3. 阅读全文
posted @ 2019-12-13 11:49 阿浪阿浪 阅读(126) 评论(0) 推荐(0)
摘要: 网络协议 1,七五协议 1. 应用层(表示层,会话层) 1. FTP协议:文件传输协议,工作TCP\IP模型的应用层,基于TCP的传输协议,面向连接的流式协议,提供可靠的数据传输 2. 规定应用程序的数据格式 2. 传输层 1. 端口协议:建立端口到端口的通行 2. TCP协议:面向链接的流式协议, 阅读全文
posted @ 2019-12-13 11:46 阿浪阿浪 阅读(113) 评论(0) 推荐(0)
摘要: 双下方法 1. 定义: 1. 双下方法是特殊方法 2. 原来是Python这个语言的程序员用于源码使用的 3. 一种特殊的机制:你不知道你干了什么就触发了某个双下方法 2. __len__ 1. 3. __hash__ 1. 类的实例化对象也是可哈希的 2. 可哈希对象得到哈希值 1. 4. _st 阅读全文
posted @ 2019-12-13 11:43 阿浪阿浪 阅读(305) 评论(0) 推荐(0)
摘要: 规范目录 1,配置starts文件 配置启动文件:将项目的启动执行命令放置在starts.py文件中,运行starts.py文件就可以成功启动项目 bin\starts.py 2,配置settings文件 配置文件中,放置一些项目中需要的静态参数,比如文件路径,数据库配置,软件的默认设置等等,在这里 阅读全文
posted @ 2019-12-13 11:16 阿浪阿浪 阅读(128) 评论(0) 推荐(0)
摘要: re模块 1,正则表达式 | | | | : | : | | \w | 匹配字母(包含中文)或数字或下划线 | | \W | 匹配非字母(包含中文)或数字或下划线 | | \s | 匹配任意的空白符(换行符,制表符,) | | \S | 匹配任意非空白符 | | \d | 匹配数字 | | \D | 阅读全文
posted @ 2019-12-13 10:45 阿浪阿浪 阅读(328) 评论(0) 推荐(0)
摘要: collection 在内置数据类型的基础上,增加了几个额外的数据类型 namedtuple 生成可以还是用名字来访问元素内容的tuple 写元组的时候,例如经纬度 deque 双端队列,可以快速的从另外一侧追加和推出对象 pass counter 计数器,主要是用来计数 计算每个元素出现的次数 o 阅读全文
posted @ 2019-12-13 10:43 阿浪阿浪 阅读(183) 评论(0) 推荐(0)
摘要: hashlib 1,定义 hashlib:摘要算法/加密算法/哈希算法/散列算法 定义:通过一个函数,把任意长度的数据按照一定规则转换为一个固定的长度的数据 串,通常用16进制的字符串表示 特征要点: bytes数据类型→通过hashlib算法→固定长度的字符串 不同的bytes类型数据转化成的结果 阅读全文
posted @ 2019-12-13 10:37 阿浪阿浪 阅读(259) 评论(0) 推荐(0)
摘要: sys模块 sys.argv 命令行参数List,第一个元素是程序本身路径 sys.modules.keys() 返回所有已经导入的模块列表 sys.exc_info() 获取当前正在处理的异常类,exc_type、exc_value、exc_traceback当前处理的异常详细信息 sys.exi 阅读全文
posted @ 2019-12-13 10:32 阿浪阿浪 阅读(643) 评论(0) 推荐(0)
摘要: os模块 1,文件夹相关 os模块是与操作系统交互的一个接口 功能:工作目录,路径,文件等相关 目录:文件夹当前目录,工作目录,父级目录,指的都是同一个,就是文件所在的文件夹 2,文件相关 3,路径相关 4,操作系统相关 5, 获取文件/目录信息的结构说明 6,工作路径 阅读全文
posted @ 2019-12-13 10:25 阿浪阿浪 阅读(763) 评论(0) 推荐(0)
摘要: pickle pickle模块是将Python中所有的数据结构以及对象转换成bytes类型,然后还可一个反序列化还原回去 Python语言识别的序列化模块,中国人作为第一交流语言,Python自带的,只有Python可用 pickle支持Python所有的数据结构类型,能将所有的数据结构序列化成特殊 阅读全文
posted @ 2019-12-13 10:23 阿浪阿浪 阅读(595) 评论(0) 推荐(0)