python线程的GIL

GIL (全局解释器锁)
python --- 》 支持多线程 ----》 同步和互斥 ---》加锁 ---》解释器加锁 ————》 解释器同一时刻只能解释一个线程

解决方法 :
* 使用 多进程代替多线程
* 使用其他解释器

单线程

line cpu: 3.2390809059143066
line IO: 3.4946115016937256

多线程
thread cpu: 3.5669941902160645
thread IO: 4.673508644104004 (如果是网络IO操作)

多进程
process cpu: 1.852142572402954
process io: 2.1611037254333496

python 并行

多进程 + 协程

设计模式

设计模式是一种编程方法和解决问题的思路,是大量长期实践中总结的最佳实践

程序设计原则 :
高内聚 : 在同一模块内,实现尽可能单一的功能,不使功能混杂
低耦合 : 不同的模块之间,尽量相互独立,减少模块间的影响

生产者消费者模式

一部分线程(进程)生产数据资源
一部分线程(进程)消耗数据资源
两者互不影响,却能够保持某种平衡

iso ---- 》 OSI模型

osi 七层模型

应用层 : 提供osi的用户服务,用什么程序处理,选择什么样的 传输层协议

表示层 :完成数据转换,格式化和压缩,和加密相关

会话层 :建立或解除节点连接

传输层 :提供什么样的传输服务,流量控制,连接的建立断开

网络层 : 提供什么样的路由选择,用户控制,网络互联

链路层: 进行消息的发送和接收,提供链路流控制

物理层: 物理接口和设备的选择,故障的检测等

4层 5层(TCP/IP模型)
应用层 应用层
传输层 传输层
网络层 网络层
物理链路层 链路层
物理层

协议 : 网络协议 ,计算机双方都必须遵守的约定。

应用层协议 : TFTP FTP NFS SMTP DNS HTTP
传输层 : TCP UDP
网络层 : IP ARP ICMP
链路层 : PPP
物理层 : IEEE 802 xxx

TCP/IP

主机 : 主机名 ----》 IP 127.0.0.1 localhost

In [3]: socket.gethostname()
Out[3]: 'tedu'

In [4]: socket.gethostbyname('localhost')
Out[4]: '127.0.0.1'

说明 : 在编程中表示网络主机通常使用该主机的ip地址
表示本机通常使用 '127.0.0.1' 'localhost' ''

IP地址

IPV4

192.168.1.12 0--255 点分十进制

可以使用32位2进制表示

IPV6 128 位

192.168.1.0网段
192.168.1.1网关地址
192.168.1.255 广播地址

In [8]: socket.gethostbyaddr('www.baidu.com')
Out[8]: ('127.0.0.1', [], ['119.75.216.20'])
主机名 别名 IP地址

地址点分十进制和二进制之间转换
In [17]: socket.inet_aton('192.8.8.8')
Out[17]: b'\xc0\x08\x08\x08'

In [18]: socket.inet_ntoa(b'\xc0\x08\x08\x08')
Out[18]: '192.8.8.8'

In [19]: socket.inet_pton(socket.AF_INET,'192.8.8.8')
Out[19]: b'\xc0\x08\x08\x08'

In [20]: socket.inet_ntop(socket.AF_INET,b'\xc0\x08\x08\x08')
Out[20]: '192.8.8.8'

端口

端口是地址的一部分,决定使用哪个应用

取值范围 1 -- 65535

1--255 众所周知的端口 256---1023 UNIX系统占用端口

1024 -- 49151 已登记端口
49152-- 65535 动态或私有端口

建议使用10000以上端口号 8888 9999 6666 8000 8800

In [29]: socket.getservbyname('ssh')
Out[29]: 22

字节序 : 信息在内存中的存储方式

大端序 : 高序字节存储在低地址

小端序: 低序字节存储在低地址

网络字节序 (大端序)

本地字节序 ----》网络字节序
socket.htons() 将16位本地字节序转换为网罗字节序
socket.htonl() 将32位本地字节序转换为网罗字节序

网络字节序 ---- 》 本地字节序
socket.ntohs() 将网罗字节序转换为16位本地字节序
socket.ntohl() 将网罗字节序转换为32位本地字节序

python学习笔记——的更多相关文章

  1. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  2. VS2013中Python学习笔记[Django Web的第一个网页]

    前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...

  3. python学习笔记之module && package

    个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...

  4. python学习笔记(六)文件夹遍历,异常处理

    python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...

  5. python学习笔记--Django入门四 管理站点--二

    接上一节  python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Autho ...

  6. python学习笔记--Django入门0 安装dangjo

    经过这几天的折腾,经历了Django的各种报错,翻译的内容虽然不错,但是与实际的版本有差别,会出现各种奇葩的错误.现在终于找到了解决方法:查看英文原版内容:http://djangobook.com/ ...

  7. python学习笔记(一)元组,序列,字典

    python学习笔记(一)元组,序列,字典

  8. Pythoner | 你像从前一样的Python学习笔记

    Pythoner | 你像从前一样的Python学习笔记 Pythoner

  9. OpenCV之Python学习笔记

    OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书< ...

  10. python学习笔记(五岁以下儿童)深深浅浅的副本复印件,文件和文件夹

    python学习笔记(五岁以下儿童) 深拷贝-浅拷贝 浅拷贝就是对引用的拷贝(仅仅拷贝父对象) 深拷贝就是对对象的资源拷贝 普通的复制,仅仅是添加了一个指向同一个地址空间的"标签" ...

随机推荐

  1. Cesium教程系列汇总【转】

    Cesium系列目录: 演示实例 ExamplesforCesium 最近老实有一些人问我,下载后在本地无法运行,我也不能保证每次都搭个环境看是否可行,或许Cesium升级版本后真有问题呢,索性在gi ...

  2. WebViewClient 简介 API 案例

    代码位置:https://github.com/baiqiantao/WebViewTest.git 设计思想理解 在WebView的设计中,不是什么事都要WebView类干的,有相当多的杂事是分给其 ...

  3. scala 学习笔记十三 特质(转载)

    转载地址:https://blog.csdn.net/dwb1015/article/details/51761510 1,介绍 Scala和java一样不允许类从多个超类继承:从多个超类继承可能会导 ...

  4. 【华为OJ平台练习题】求最大公共子串的个数和元素

    1.原题是求出最大公共子串的个数就可以 原理:利用二维矩阵排列的方式.将俩字符串进行比較 #include <iostream> #include <vector> using ...

  5. Android -- Gradle

    使用gradle的目的 更容易重用资源和代码: 可以更容易创建不同的版本的程序,多个类型的apk包: 更容易配置,扩展; 更好的IDE集成; Gradle基本结构 使用ide创建的gradle构建的项 ...

  6. windows CMD命令查看局域网内所有主机名及IP

    COLOR 0A CLS @ECHOOff Title查询局域网内在线电脑IP :send @ECHO off&setlocal enabledelayedexpansion ECHO 正在获 ...

  7. 转: 用 Eclipse 平台进行 C/C++ 开发

    http://www.ibm.com/developerworks/cn/linux/opensource/os-ecc/index.html

  8. Failed to fetch URL https://dl-ssl.google.com/android/repository/repository-6.xml, reason: Connection to https://dl-ssl.google.com refused

    修改hosts文件.文件在C:\WINDOWS\system32\drivers\etc目录下,Linux用户打开/etc/hosts文件.用记事本打开文件后添加以下内容. #Google主页203. ...

  9. 在MyEclipse中设置jsp页面为默认utf-8编码(转)

    http://www.cnblogs.com/xdp-gacl/p/3496161.html 在MyEclispe中创建Jsp页面,Jsp页面的默认编码是“ISO-8859-1”,如下图所示: 在这种 ...

  10. java面试第十二天

    多线程: 多线程的同步: 多线程并发访问同一个对象(临界资源),如果不对线程进行同步控制,破坏了原子操作(不可再分的操作),则会造成临界资源(两个线程同时访问的资源)的数据不一致. 每一个对象都有一个 ...