博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python学习笔记十一
阅读量:4974 次
发布时间:2019-06-12

本文共 2415 字,大约阅读时间需要 8 分钟。

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       

      

 

转载于:https://www.cnblogs.com/yangjianbo/p/7934834.html

你可能感兴趣的文章
[django实践]投票app
查看>>
[django]form的content-type(mime)
查看>>
JQUERY —— 绑定事件
查看>>
在TabControl中的TabPage选项卡中添加Form窗体
查看>>
oracle中SET DEFINE意思
查看>>
个人作业-最长英语链
查看>>
JMeter-性能测试之报表设定的注意事项
查看>>
1066-堆排序
查看>>
仿面包旅行个人中心下拉顶部背景放大高斯模糊效果
查看>>
强大的css3
查看>>
c#中的组件拖拽和MouseMove事件
查看>>
C# 小叙 Encoding (二)
查看>>
python创建对象数组避免浅拷贝
查看>>
CSS自学笔记(14):CSS3动画效果
查看>>
项目应用1
查看>>
Ubuntu下配置jdk和tomcat
查看>>
大型网站的演变升级
查看>>
图片延迟加载的实现
查看>>
php适配器模式(adapter pattern)
查看>>
C# 委托链(多播委托)
查看>>