1. 操作系统的发展历程

    • 主要的人机矛盾是什么 : CPU的使用率

      • 输入\输出数据和CPU计算没有关系
    • 操作系统是怎么进化的
      • 传统的纸带输入
      • 磁带的存储降低了输入输出数据占用的时间,提高了CPU的利用率
      • 多道操作系统的出现 : 提高了CPU的利用率,单纯的切换会浪费时间
        • 一台计算机上同时可以出现多个任务
        • 能够将多个任务所使用的资源隔离开
        • 当一个任务遇到输入输出工作的时候能够让另一个任务使用CPU去计算
      • 分时操作系统 : 降低了cpu的利用率,提高了用户的体验
        • 时间片轮转
      • 实时操作系统
        • 操作精密仪器或者设备
        • 实时交易类
    • 操作系统的作用
      • 在具体的应用与所有的硬件之间起到了一个协调管理的作用
      • 负责分配计算机中所有的资源
  2. 输入输出 Input/Output
    • 向内存输入 : read,recv,recvfrom,import,input
    • 从内存输出 : write,send,sendto,print
      CPU的工作效率和输入输出的工作效率差
  3. 并发和并行
    • 多个程序交替在同一个cpu上被计算 并发
    • 多个程序同时在多个cpu上被计算 并行
      阻塞/非阻塞
    • 阻塞 CPU不工作
    • 非阻塞 CPU一直在工作
      异步和同步
    • 异步 :发布一个任务,不等待这个任务的结果就继续执行我的任务
    • 同步 :发布一个任务,等待获取这个任务的结果之后才继续执行我的任务
      同步阻塞/同步非阻塞/异步阻塞/异步非阻塞
  4. 进程和程序
    • 进程就是运行中的程序
    • 每一个进程在计算机中都有一个唯一的进程id,pid process id
  5. 进程 是计算机中资源分配的最小单位
    • 三状态 : 就绪 运行 阻塞
  6. 线程 是计算机中能够被CPU调度的最小单位
    • 是进程中的一个单位,它不能独立存在

举例

  • 研究生 5min 没有io操作 15min
  • 老教授 24h 没有io操作 24 + n分钟
  • 研究生 3min 没有io操作 9min
    • 短作业优先算法
    • 先来先服务算法 FCFS
  • 把CPU的时间分成很小的时间片
  • 一会儿执行研究生A的任务,时间片到
  • 执行老教授,时间片到
  • 执行研究生B

课上代码

下载和校验

Server

# 认证 + 上传 + 下载 + 校验
import os
import sys
import json
import struct
import socket
import hashlib
upload_path = r'D:\PyCharmProject\s20\day31\下载和校验\upload'
def get_md5(usr,pwd):
    md5 = hashlib.md5(usr.encode('utf-8'))
    md5.update(pwd.encode('utf-8'))
    return md5.hexdigest()

def pro_recv(conn):
    num = conn.recv(4)
    num = struct.unpack('i', num)[0]
    str_dic = conn.recv(num).decode('utf-8')
    dic = json.loads(str_dic)
    return dic

def pro_send(conn,dic,pro = True):
    bytes_dic = json.dumps(dic).encode('utf-8')
    if pro:
        len_bytes = struct.pack('i', len(bytes_dic))
        conn.send(len_bytes)
    conn.send(bytes_dic)

def login(conn):
    dic = pro_recv(conn)
    with open('userinfo', encoding='utf-8') as f:
        for line in f:
            user, pwd = line.strip().split('|')
            if user == dic['user'] and pwd == get_md5(dic['user'], dic['passwd']):
                return {'opt':'login','flag':True}
        else:
            return {'opt': 'login', 'flag': False}

def upload(dic,conn):
    file_path = os.path.join(upload_path,dic['filename'])
    with open(file_path,'wb') as f:
        while dic['filesize']:
            content = conn.recv(2048)
            f.write(content)
            dic['filesize'] -= len(content)

def download(dic,conn):
    path = os.path.join(upload_path,dic['filename'])
    if os.path.isfile(path):
        # 文件存在,先发字典,再发文件
        filesize = os.path.getsize(path)
        dic = {'filesize':filesize,'exist':True}
        pro_send(conn,dic)
        with open(path,'rb') as f:
            while filesize > 2048:
                content = f.read(2048)
                conn.send(content)
                filesize -= len(content)
            else:
                content = f.read()
                conn.send(content)
    else:
        # 文件不存在,先发字典,然后结束
        dic = {'exist':False}
        pro_send(conn, dic)

sk = socket.socket()
sk.bind(('127.0.0.1',9001))
sk.listen()

conn,_ = sk.accept()
ret = login(conn)
bytes_ret = json.dumps(ret).encode('utf-8')
conn.send(bytes_ret)
if ret['flag']:
    while True:
        dic = pro_recv(conn)
        if hasattr(sys.modules[__name__],dic['operate']):
            getattr(sys.modules[__name__],dic['operate'])(dic,conn)
else:
    conn.close()

Client

import os
import json
import struct
import socket

download_path = r'D:\PyCharmProject\s20\day31\下载和校验\download'

def pro_send(sk,dic,pro = True):
    bytes_dic = json.dumps(dic).encode('utf-8')
    if pro:
        len_bytes = struct.pack('i', len(bytes_dic))
        sk.send(len_bytes)
    sk.send(bytes_dic)

def pro_recv(sk,pro = True,num=1024):
    if pro:
        num = sk.recv(4)
        num = struct.unpack('i', num)[0]
    str_dic = sk.recv(num).decode('utf-8')
    dic = json.loads(str_dic)
    return dic

def upload(sk):
    # 文件的上传,考虑是大文件,先发送文件信息,再发送文件内容
    file_path = input('文件路径 :')
    if os.path.isfile(file_path):
        filename = os.path.basename(file_path)
        filesize = os.path.getsize(file_path)
        dic = {'filename':filename,'filesize':filesize,'operate':'upload'}
        pro_send(sk,dic)
        with open(file_path,'rb') as f:
            while filesize > 2048:
                content = f.read(2048)
                sk.send(content)
                filesize -= len(content)
            else:
                content = f.read()
                sk.send(content)
        print('上传成功')
    else:
        print('您要上传的文件不存在')

def download(sk):
    filename = input('文件名 :')
    # 要下载,并且先发送要下载文件的名字
    dic = {'filename':filename,'operate':'download'}
    pro_send(sk,dic)
    # server回复:这个文件是否存在,文件的大小
    ret = pro_recv(sk)
    if ret['exist']:
        file_path = os.path.join(download_path,filename)
        # 根据文件大小来接收文件,收到的文件存储在download文件夹下的
        with open(file_path, 'wb') as f:
            while ret['filesize']:
                content = sk.recv(2048)
                f.write(content)
                ret['filesize'] -= len(content)
        print('下载成功')
    else:
        print('您要下载的文件不存在')

# def login():
#     username = input('用户名 :')
#     password = input('密 码:')
#     dic = {'user': username, 'passwd': password, 'operate': 'login'}
#     sk = yield
#     pro_send(sk, dic)

def login2():
    username = input('用户名 :')
    password = input('密 码:')
    dic = {'user': username, 'passwd': password, 'operate': 'login'}
    sk = socket.socket()
    sk.connect(('127.0.0.1', 9001))
    pro_send(sk, dic)
    dic_ret = pro_recv(sk,pro = False)
    if dic_ret['opt'] == 'login' and dic_ret['flag']:
        print('登陆成功')
    else:
        print('登陆失败')
        sk.close()
    return sk,dic_ret['flag']

# g = login()
# next(g)
# sk = socket.socket()
# sk.connect(('127.0.0.1',9001))
# g.send(sk)

sk,flag = login2()
while flag:
    operate = [('上传',upload),('下载',download)]
    for ind,opt in enumerate(operate,1):
        print(ind,opt[0])
    num = int(input('请输入您要选择的操作 :'))
    operate[num-1][1](sk)

2019-04-12-day031-进程基础的更多相关文章

  1. 2019.04.12 Head First

    第一节 认识python python.exe -V python 会进入解释器 quit()命令会退出解释器 IDEL,一个python的集成开发环境,能够利用颜色突出语法的编辑器,一个调试工具,P ...

  2. 36.React基础介绍——2019年12月24日

    2019年12月24日16:47:12 2019年10月25日11:24:29 主要介绍react入门知识. 1.jsx语法介绍 1.1 介绍 jsx语法是一种类似于html标签的语法,它的作用相当于 ...

  3. 20.Nodejs基础知识(上)——2019年12月16日

    2019年12月16日18:58:55 2019年10月04日12:20:59 1. nodejs简介 Node.js是一个让JavaScript运行在服务器端的开发平台,它让JavaScript的触 ...

  4. 19.go语言基础学习(下)——2019年12月16日

    2019年12月16日16:57:04 5.接口 2019年11月01日15:56:09 5.1 duck typing 1. 2. 接口 3.介绍 Go 语言的接口设计是非侵入式的,接口编写者无须知 ...

  5. 16.go语言基础学习(上)——2019年12月16日

    2019年12月13日10:35:20 1.介绍 2019年10月31日15:09:03 2.基本语法 2.1 定义变量 2019年10月31日16:12:34 1.函数外必须使用var定义变量 va ...

  6. 7.搭建hyperledger fabric环境及启动——2019年12月12日

    2019年12月12日13:05:16 声明:从网络中学习整理实践而来. 1.介绍fabric Fabric 是一个面向企业应用的区块链框架,基于 Fabric 的开发可以粗略分为几个层面: 1. 参 ...

  7. Ubuntu LTS 系统学习使用体会和实用工具软件汇总 6.04 8.04 10.04 12.04 14.04 16.04

    Ubuntu LTS 系统学习体会和工具软件汇总 6.04 8.04 10.04 12.04 14.04 16.04 ubuntu入门必备pdf:http://download.csdn.net/de ...

  8. PowerBI更新2019/04 - 解决方案架构 - PowerBI Solution Architecture(一图胜万字!)

    Power BI 架构图 (2019/04) 1) Power BI Desktop 是一个免费的工具.它可以用来准备和管理数据模型:包括链接各种数据:做数据清洗:定义关系:定义度量值和层级关系:应用 ...

  9. 35.ES6语法介绍——2019年12月24日

    2019年12月24日16:22:24 2019年10月09日12:04:44 1. ES6介绍 1.1 新的 Javascript 语法标准 --2015年6月正式发布 --使用babel语法转换器 ...

  10. 24.mongodb可视化工具部署——2019年12月19日

    2019年10月09日17:05:54 教程链接:https://blog.csdn.net/qq_32340877/article/details/79142129 项目名:adminMongo g ...

随机推荐

  1. Android项目第一天,下载安装Android Studio和“我的第一个安卓项目”

    一.AS的下载我是在AS官方网站进行下载的最新版本,如图所示 二.AS的安装过程 点击你下载的安装包安装即可,傻瓜式一站到底. 到这一步时选择第二个按钮, 随后出现如下界面 这个窗口是提示我们设置代理 ...

  2. JavaScript实现全屏显示

    <!doctype html> <html> <head> <title>全屏显示</title> <meta charset=&qu ...

  3. .net基本面试题

    OOP: Object Oriented Programming: 面向对象编程技术的关键性观念是它将数据及对数据的操作行为放在一起,作为一个相互依存.不可分割的整体——对象.对于相同类型的对象进行分 ...

  4. 一次Webservice请求的流程

  5. python爬虫——与不断变化的页面死磕和更新换代(3)

    经过上一次的实战,手感有了,普罗西(雾)池也有了,再战taobao/tmall 试着使用phantomJS爬手机端,结果发现爬来的tmall页面全是乱码,taobao页面xpath识别错误.一顿分析了 ...

  6. Java爬取B站弹幕 —— Python云图Wordcloud生成弹幕词云

    一 . Java爬取B站弹幕 弹幕的存储位置 如何通过B站视频AV号找到弹幕对应的xml文件号 首先爬取视频网页,将对应视频网页源码获得 就可以找到该视频的av号aid=8678034 还有弹幕序号, ...

  7. Maven+SSM框架(Spring+SpringMVC+MyBatis)(二)

    1.基本概念 2.开发环境搭建 3.Maven Web项目创建 4.SSM整合 此次整合我分两个配置文件: 1)分别是spring-mybatis.xml,包含spring和mybatis的配置文件, ...

  8. opencv学习之路(30)、分水岭算法及图像修补

    一.简介 二.分水岭算法 #include "opencv2/opencv.hpp" using namespace cv; void main() { Mat srcImg = ...

  9. docker启动容器报错: could not synchronise with container process: not a directory

    错误现象 在运行容器时,出现以下错误 [root@localhost test]# docker run -it -d -v $PWD/test.txt:/mydir mytest fd44cdc55 ...

  10. mvc 之 配置EF+oralce

    只需要在项目中加载nuGet包就可以了 操作:工具--nuGet包管理器--程序包管理器控制台 在 PM>处输入 install-package entityframework 加载sqlser ...