Python学习笔记十一
1. 协程
并发的解决方案:
多进程
多线程
什么叫并发:看起来同时进行
如何实现并发:切换+保存状态
进程线程都是由操作系统调度的
协程:单线程下实现的并发,应用程序级别的切换,操作系统无法感知
找到一个解决方案:1.在多个任务直接切换+保存状态
2.检测应用程序的IO,实现遇到IO才切换。
并发提高效率:遇到IO的时候切换,才能提高效率,如果是计算,就不会提高效率。
yield:能实现协程,但是不能提高效率。
greenlet:需要pip3 install greenlet
from greenlet import greenlet
g1=greenlet()
g1.switch()
2. gevent()
安装:pip3 install gevent
from gevent import monkey
monkey.patch_all() 这两行代码写到文件的首部
import gevent
gevent.sleep(2)
g1=gevent.spawn(eat,name='egon')
g2=gevent.spawn(play,'alex')
g1.join()
g2.join()
3. 利用gevent写一个socket连接。
单线程实现并发连接
4. socketserver模块
基于TCP
import socketserver
class MyTCPhandler(socketserver.BaseRequestHandler): #通信
def hanler(self):
while True:
data=self.request.recv(1024)
self.request.send(data.upper())
if __name__=='__main__':
socketserver.ForkingTCPServer #windows不能使用多进程模式
s=socketserver.ThreadingTCPServer(('127.0.0.1',8080),MyTCPhandler)
s.server_forever()
基于UDP:
import socketserver
class MyTCPhandler(socketserver.BaseRequestHandler): #通信
def hanler(self):
client_data=self.request[0]
self.request[1].sendto(client_data.upper(),self.client_address)
if __name__=='__main__':
socketserver.ForkingTCPServer #windows不能使用多进程模式
s=socketserver.ThreadingTCPServer(('127.0.0.1',8080),MyTCPhandler)
s.server_forever()
5. 数据库介绍及mysql安装
yum install mysql_server mysql -y
6. mysql的基本管理
mysql -h127.0.0.1 -uroot -p
mysqld --install
设置密码:
mysqladmin -uroot -p password "123";
破解密码:
net stop mysql
mysqld --skip-grant-tables 跳过授权表
mysql -uroot -p
update mysql.user set password=password('') where user='root' and host='localhost';
flush privileges;
修改my.ini配置文件。
在mysqld里面设置:skip-grant-tables
[mysqld]
[mysql] mysql自带的客户端
user='root'
password='123'
[client] 所有的客户端
user='root'
password='123'
建立账号:
grant select,update on *.* to
7. mysql的基本sql语句
库 增删改查
表 增删改查
记录 增删改查
8. mysql的存储引擎
innodb
9. mysql的数据类型:
数字类型:
整型:默认有符号,指定无符号:unsigned
int
tinyint
bigint
浮点型
float
double
decimal
字符类型
char
varchar
时间类型
date
time
datetime
timestamp
year
枚举类型
enum
setn
Python学习笔记十一的更多相关文章
- python 学习笔记十一 SQLALchemy ORM(进阶篇)
SqlAlchemy ORM SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据A ...
- Python学习笔记十一:模块
标准库(内置模块) time与datetime 模块 时间表示方式 1.时间戳 2.格式化的字符串 3.元组形式 时间戳就是一个秒数 x=time.time(),从1970年1月1日0时0分0秒到现在 ...
- python学习笔记十一:操作mysql
一.安装MySQL-python # yum install -y MySQL-python 二.打开数据库连接 #!/usr/bin/python import MySQLdb conn = MyS ...
- python学习笔记(十一)redis的介绍及安装
一.redis简介 1.redis是一个开源的.使用C语言编写的.支持网络交互的.可基于内存也可持久化的Key-Value数据库. 2.redis的官网地址,非常好记,是redis.io. ...
- python学习笔记(十一)-python程序目录工程化
在一个程序当中,一般都会包含文件夹:bin.conf.lib.data.logs,以及readme文件. 所写程序存放到各自的文件夹中,如何进行串联? 首先,通过导入文件导入模块方式,引用其他人写好的 ...
- Python学习笔记(十一)
Python学习笔记(十一): 生成器,迭代器回顾 模块 作业-计算器 1. 生成器,迭代器回顾 1. 列表生成式:[x for x in range(10)] 2. 生成器 (generator o ...
- Python学习笔记,day5
Python学习笔记,day5 一.time & datetime模块 import本质为将要导入的模块,先解释一遍 #_*_coding:utf-8_*_ __author__ = 'Ale ...
- python3.4学习笔记(十一) 列表、数组实例
python3.4学习笔记(十一) 列表.数组实例 #python列表,数组类型要相同,python不需要指定数据类型,可以把各种类型打包进去#python列表可以包含整数,浮点数,字符串,对象#创建 ...
- Go语言学习笔记十一: 切片(slice)
Go语言学习笔记十一: 切片(slice) 切片这个概念我是从python语言中学到的,当时感觉这个东西真的比较好用.不像java语言写起来就比较繁琐.不过我觉得未来java语法也会支持的. 定义切片 ...
随机推荐
- css 图像热区
CSS图像热区 在img标签当中,存在一个属性usemap属性,用来和map标签进行绑定,从而实现图像热区.所谓的图像热区,其实指的是在图像中插入一个连接,当用户点击图像的指定区域后就会进行页面跳转. ...
- Android Intent 传递数据注意事项
不要通过 Intent 在 Android 基础组件之间传递大数据(binder transaction缓存为 1MB),可能导致 OOM.
- 【JVM】JVM随笔索引
JVM目录 [JVM]Java内存模型 [JVM]类加载机制 [JVM]深度分析Java的ClassLoader机制(源码级别) [JVM]关于类加载器准备阶段的一道面试题目 [JVM]JVM垃圾收集 ...
- [模板]fhqTreap
用途 平衡树(可实现区间翻转) 原理 和treap一样,中序遍历表示权值的顺序,并且每个点有一个随机的附加值,形成一个堆来保证复杂度 但是不旋转,所有操作通过split和merge实现 分为两种spl ...
- python 内置函数详解
懒得写了 参考1:https://www.cnblogs.com/xiao1/p/5856890.html 参考2:https://www.runoob.com/python/python-buil ...
- kubernetes 部署
kubernetes 部署(Centos 7) 一个或者多个兼容 deb 或者 rpm 软件包的操作系统,比如 Ubuntu 或者 CentOS 每台机器 2 GB 以上的内存,内存不足时应用会受限制 ...
- 目前的.NET 主流的后端ORM框架
转自:https://www.cnblogs.com/yeminglong/p/9518438.html 推荐一些常用的asp.net ORM框架 SqlSugar (国内) Dos.ORM (国内 ...
- ef mysql
App.config <configuration> <configSections> <!-- For more information on Entity Frame ...
- 2018-2019-2 网络对抗技术 20165337 Exp4 恶意代码分析
1.实践目标 1.1是监控你自己系统的运行状态,看有没有可疑的程序在运行. 1.2是分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分析工具尽量使用原生指令或sysinternals,sys ...
- mysql数据库 表 导入导出
1.导出表结构 mysqldump --no-data -h192.168.222.11 -uroot -proot --databases db01 db02 db30>file.sql 2. ...