4.3 - 并发编程 - 总结练习题

1.简述计算机操作系统中的“中断”的作用?
cpu会切:
io阻塞,程序运行时间过长
中断:计算机执行期间,系统内发生任何非寻常的或非预期的急需处理事件,使得cpu暂时中断当前正在执行的程序而转去执行相应的事件处理程序.
待处理完毕后又返回原来被中断处继续执行或调度新的进程执行的过程.
它使计算机可以更好更快利用有限的系统资源解决系统响应速度和运行效率的一种控制技术.
实时响应 + 系统调用
2.简述计算机内存中的“内核态”和“用户态”;
内核态:运行操作系统的程序,os的数据存放
用户态:运行用户程序,用户进程的数据存放
用户态的应用程序可以通过三种方式来访问内核态的资源:
1)系统调用
2)库函数
3)Shell脚本
用户态到内核态的切换:
1.系统调用 用户程序主动发起的 软中断 os.fork() process
2.异常 被动的 当CPU正在执行运行在用户态的程序时,突然发生某些预先不可知的异常事件,这个时候就会触发从当前用户态执行的进程
转向内核态执行相关的异常事件,典型的如缺页异常。
3.外围设备的硬中断 被动的 外围设备完成用户的请求操作后,会像CPU发出中断信号,此时,CPU就会暂停执行下一条即将要执行的指令,
转而去执行中断信号对应的处理程序,如果先前执行的指令是在用户态下,则自然就发生从用户态到内核态的转换。

参考:https://www.cnblogs.com/bakari/p/5520860.html
https://blog.csdn.net/qq_34228570/article/details/72995997
3.进程间通信方式有哪些?
进程间通信(IPC),队列和管道(使用消息传递的)
队列 = 管道 + 锁
4.简述你对管道、队列的理解;
队列 = 管道 + 锁
5.请列举你知道的进程间通信方式;
队列,信号量,Event事件,定时器Timer,线程queue,进程池线程池,异步调用+回调机制
6.什么是同步I/O,什么是异步I/O?
synchronous io: 做”IO operation”的时候会将process阻塞;”IO operation”是指真实的IO操作
blocking IO,non-blocking IO,IO multiplexing都属于synchronous IO这一类.
asynchronous io: 当进程发起IO 操作之后,就直接返回再也不理睬了,直到kernel发送一个信号,
告诉进程说IO完成。在这整个过程中,进程完全没有被block。异步io的实现会负责把数据从内核拷贝到用户空间。
7.请问multiprocessing模块中的Value、Array类的作用是什么?举例说明它们的使用场景
8、请问multiprocessing模块中的Manager类的作用是什么?与Value和Array类相比,Manager的优缺点是什么?
9.写一个程序,包含十个线程,子线程必须等待主线程sleep 10秒钟之后才执行,并打印当前时间
 1 from threading import Thread
 2 import time
 3 
 4 def task(name):
 5     print(name,time.strftime('%Y-%m-%d %H:%M:%S',time.localtime()))
 6 
 7 if __name__ == "__main__":
 8     time.sleep(10)
 9     for i in range(10):
10         t = Thread(target=task,args=('线程 %s'%i,))
11         t.start()
10.写一个程序,包含十个线程,同时只能有五个子线程并行执行;
 1 from threading import Thread,currentThread
 2 from concurrent.futures import ThreadPoolExecutor
 3 import time
 4 import random
 5 
 6 def task():
 7     print(currentThread().getName())
 8     time.sleep(random.randint(1,3))
 9 
10 if __name__ == "__main__":
11     pool = ThreadPoolExecutor(5)
12     for i in range(10):
13         pool.submit(task)
11. 写一个程序,要求用户输入用户名和密码,要求密码长度不少于6个字符,且必须以字母开头,
如果密码合法,则将该密码使用md5算法加密后的十六进制概要值存入名为password.txt的文件,超过三次不合法则退出程序;
 1 import hashlib
 2 import json
 3 import re
 4 
 5 def func():
 6     count = 0
 7     while count < 3:
 8         username = input('username>>>:').strip()
 9         password = input('password>>>:').strip()
10         if len(password) < 6 or not re.search('\A([a-z]|[A-Z])',password):
11             count += 1
12         else:
13             obj = {'usename':username,'password':hashlib.md5(password.encode('utf-8')).hexdigest()}
14             json.dump(obj,open('password.txt','a',encoding='utf-8'))
15             break
16 
17 if __name__ == "__main__":
18     func()
12.写一个程序,使用socketserver模块,实现一个支持同时处理多个客户端请求的服务器,要求每次启动一个新线程处理客户端请求;
 1 # server
 2 import socketserver
 3 
 4 class Handler(socketserver.BaseRequestHandler):   # 必须继承BaseRequestHandler
 5     def handle(self):    # 必须有handle方法
 6         print('new connection:',self.client_address)
 7         while True:
 8             try:
 9                 data = self.request.recv(1024)
10                 if not data:break
11                 print('client data:',data.decode())
12                 self.request.send(data.upper())
13             except Exception as e:
14                 print(e)
15                 break
16 
17 if __name__ == "__main__":
18     server = socketserver.ThreadingTCPServer(('127.0.0.1',8080),Handler)  # 实例化对象,实现多线程的socket
19     server.serve_forever()  # 事件监听,并调用handler方法
20 
21 # client
22 import socket
23 client = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
24 client.connect(('127.0.0.1',8080))
25 while True:
26     msg = input(">>>:").strip()
27     if not msg:continue
28     client.send(msg.encode('utf-8'))
29     data = client.recv(1024)
30     print(data.decode('utf-8'))




posted @ 2018-04-05 20:34  Alice的小屋  阅读(345)  评论(0编辑  收藏  举报