当前位置: 首页 > news >正文

网站怎么做备案汕头网站制作设计

网站怎么做备案,汕头网站制作设计,手机便宜的网站建设,长沙网站设计哪里好Python python 没有多态,而是鸭子类型 多继承,没有接口,可通过语法糖实现接口的作用 lambda中只能有一句 "/"表示之前的参数是必须是位置参数,”**“表示是后面的必须是关键字参数 Python多进程 Python 多线程是伪多线…

Python
python 没有多态,而是鸭子类型
多继承,没有接口,可通过语法糖实现接口的作用
lambda中只能有一句
"/"表示之前的参数是必须是位置参数,”**“表示是后面的必须是关键字参数

Python多进程

在这里插入图片描述

Python 多线程是伪多线程

多线程子线程会随着主线程结束而中断,因此一般在主线程中调用thread.join()

线程方法

import threading t = thread.Thread() t.start(); # 没有返回值,若需要返回值可继承该类,在类中保存计算结果,用以获取 # 或者传入全局结果参数,
import thread # threading 封装了thread
import threadpool # 三方库

import threading
t = thread.Thread()
t.start();
# 没有返回值,若需要返回值可继承该类,在类中保存计算结果,用以获取
# 或者传入全局结果参数,
import thread # threading 封装了thread
import threadpool # 三方库
# 线程池
import asyncio
async def coro(i):print("core start",i)ret = await get(i) # 此处为耗时的io等操作print("core end",i)return ret
async def get(i):await asyncio.sleep(5)return i
loop = asyncio.get_event_loop()
a = [asyncio.ensure_future(coro(i)) for i in range(10)]
loop.run_until_complete(asyncio.wait(a))
loop.close()
print([i.result() for i in a])import concurrent.futures
with concurrent.futures.ThreadPoolExecutor() as pool:results = pool.map(function,args)   # 注意此处是任务提一提交完,args为参数列表的列表# result 线程的结果# 或者future = pool.submit(function,args)  # 每次提交一个future.result() # 结果for futures in futures: # 顺序执行xxxxfor futures in concurrent.futures.as_completed(futures): # 不会按照顺序执行,那个线程先结束先执行那个xxxx

Python协程

单线程的IO多路复用,使用了单线程中IO阻塞的那一段时间,但其实还是顺序执行,按照IO阻塞切换,因此不会出现协程安全问题,可以说是异步操作,开销小,切换容易。

在这里插入图片描述

GIL锁:全局解释器锁,Cython

cpu计算时线程需要获取GIL锁,只有一个,因此多核cpu也只有一个线程可以执行,主要防止多线程垃圾回收不安全

GIL只保证有一个线程运行,但不保证线程何时切换,因此还有线程安全问题。

程序代码现线程安全问题还是要加LOCK

import threading
lock = threading.Lock()
lock.acquire()
lock.release()
# 或者
with lock:xxxx 

执行IO操作时会释放锁,因此对于IO密集型任务,可以用多线程,计算密集型,不能发挥多核,多线程作用。

引用计数法+循环检测:GC

面向对象

类中的变量是静态变量,方法通过@staticmethod修饰,是静态,self.xxx=yy 实例变量

WWW

import urllib.request
if __name__ == '__main__':data = urllib.parse.urlencode({'wd':'python'}).encode("utf8")request = urllib.request.urlopen("http://baidu.com",data=data)with request:msg,hd = request.read(),request.info()print(msg)print(hd)

SMTP

# smtplib email 配合使用
# 或是unix系统中的sendmail命令

SOCKET

# 旧版本异步通信
import asyncore
class HTTPClient(asyncore.dispatcher):def __init__(self,host):#  初始化父类asyncore.dispatcher.__init__(self)# 创建一个socket对象self.create_socket()# 连接服务器端self.connect((host,80))#发送优化self.buffer = b'GET /HTTP/1.1\r\nHost: www.baidu.com\r\n\r\n'def handle_connect(self):print('服务器连接成功')def handle_close(self):print('服务器连接断开')self.close()def readable(self):return Truedef handle_read(self):# 指定一次读取1024个字节,如果一次没有读完的话,那么事件循环会分多次把内容读完为止print(self.recv(1024).decode())def writable(self):return (len(self.buffer)>0)def handle_write(self):sent = self.send(self.buffer)self.buffer = self.buffer[sent:]
if __name__ == '__main__':HTTPClient('www.baidu.com')asyncore.loop()import asyncore
import socketclass EchoHandler(asyncore.dispatcher_with_send):def handle_read(self):data = self.recv(8192)if data:self.send("hello".encode('utf8')+data)
class EchoServer(asyncore.dispatcher):def __init__(self, host, port):asyncore.dispatcher.__init__(self)self.create_socket(socket.AF_INET, socket.SOCK_STREAM)self.set_reuse_addr()self.bind((host, port))self.listen(5)def handle_accept(self):pair = self.accept()if pair is not None:sock, addr = pairprint('Incoming connection from %s' % repr(addr))handler = EchoHandler(sock)
if __name__ == '__main__':server = EchoServer('10.101.33.82', 8080)asyncore.loop()
import asyncio
async def handle_echo(reader, writer):while True:data = await reader.read(100)message = data.decode("gbk")addr = writer.get_extra_info('peername')print(f"Received {message!r} from {addr!r}")if message == '-1':writer.write("将会结束!".encode("gbk"))else:writer.write(message.encode("gbk"))await writer.drain()if message == '-1':writer.close()break
async def main():server = await asyncio.start_server(handle_echo, '10.101.33.82', 8080)addr = server.sockets[0].getsockname()print(f'Serving on {addr}')async with server:await server.serve_forever()asyncio.run(main())

编码

# 编码,utf8
#3字节 1110xxxx 10xxxxxx 10xxxxxx   中文:"中"
# utf8--> 4e2d -》0100 1110 0010 1101
b'\xe4\xb8\xad'.decode('utf8') # “中“
# 与上边组 1110 0100 10111000 10101101 -》就是 e4b8ad

b’xxxxx’ xxxx 应该是字节数,例如ascii中的,或者是用16进制表示的汉字。

b’a’ == b’\x61’。

b’\e4\xb8\xad’ 按照utf8解码后就是‘中’。

图形界面

Python3 Tkinter Qt

wxwidgets,Kivy,Fltk

http://www.hkea.cn/news/533311/

相关文章:

  • 小程序招商加盟平台我是seo关键词
  • wordpress 发帖机镇江抖音seo
  • 网站建设的小结可以发外链的论坛有哪些
  • 网站正常打开速度网店营销与推广策划方案
  • 义乌 网站制作进入百度app
  • 做外围网站赌球红树林seo基础入门免费教程
  • 绿色风格网站seo排名赚钱
  • 南宁企业免费建站百度推广营销怎么做
  • 建立个人网站的成本短视频seo营销系统
  • 深圳公司名称大全网站结构优化的内容和方法
  • 安康市代驾公司上海网站关键词排名优化报价
  • 怎么在网站上建设投票统计在线培训系统app
  • 泰州网站建设哪家好网站seo的主要优化内容
  • 洛卡博网站谁做的seo权重查询
  • 东莞网络科技公司有哪些山东网站seo
  • 网站建设需要学什么网站模板购买
  • 用html做的游戏网站关键词推广效果分析
  • 做影视网站引流正规推广平台有哪些
  • 免费下载简历模板北京seo排名厂家
  • 西昌市做网站的百度搜索排名靠前
  • 办公室装修实景拍摄图重庆seo俱乐部联系方式
  • 网站建设阶段推广计划书怎么写
  • 代做毕业设计网站现成注册网站平台
  • 电商网站开发工作计划企业网络营销策划
  • 用wps网站栏目做树形结构图网页设计代码案例
  • 多媒体网站设计开发是指什么每日关键词搜索排行
  • 网站 seo正规网络公司关键词排名优化
  • 建立网站赚多少钱seo收录排名
  • 怎么做app网站seo学习网站
  • 广西建设职业技术学院官网免费的seo优化