python20181223

Posted zhanggd

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python20181223相关的知识,希望对你有一定的参考价值。

1.什么是面向对象的mro

 

mro是为了找到当前的类的继承顺序关系。

 

2.json序列化时,默认遇到中文会转换成unicode,如果想要保留中文怎么办?

 

在序列化时,中文汉字总是被转换为unicode码,在dumps函数中添加参数ensure_ascii=False即可解决。

 

3.简述 yield关键字。

 

生成迭代器

 

4.简述 OSI 七层协议。

 

物理层,数据链路层,网络层,传输层,会话层,表示层,应用层

 

5.什么是C/S和B/S架构?

 

C / S也称为客户端/服务器或客户端/服务器模式。服务器通常使用高性能PC,工作站或小型计算机,并使用大型数据库系统,如Oracle,Sybase,Informix或SQL Server。客户端需要安装专用的客户端软件。

B / S是Brower / Server的缩写。客户端只需要安装浏览器,例如Netscape Navigator或Internet Explorer。服务器安装Oracle,Sybase,Informix或SQL Server等数据库。浏览器通过Web服务器与数据库交互。

 

6.简述 三次握手、四次挥手的流程。

 

三次握手:
    第一次握手
1:客户端先向服务端发起一次询问建立连接的请求,并随机生成一个值作为标识
    第二次握手
2:服务端向客户端先回应第一个标识,再重新发一个确认标识
    第三次握手
3:客户端确认标识,建立连接,开始传输数据

 

7.GIL锁是什么鬼

 

GIL本质就是一把互斥锁,既然是互斥锁,所有互斥锁的本质都一样,都是将并发运行变成串行,以此来控制同一时间内共享数据只能被一个任务所修改,进而保证数据安全。

 

8.流式套接字有什么特点

 

9.如何在一个function里面设置一个全局的变量? 

 

解决方法是在function的开始插入一个global声明

 

10.python下多线程的限制以及多进程中传递参数的方式

 

python多线程有个全局解释器锁(global interpreter lock),这个锁的意思是任一时间只能有一个线程使用解释器,跟单cpu跑多个程序一个意思,大家都是轮着用的,这叫“并发”,不是“并行”。
多进程间共享数据,可以使用 multiprocessing.Value 和 multiprocessing.Array

 

11.什么是pickling和unpickling?

 

编程练习

1.创建一个文件,文件的第一行写入0,再创建20个任务线程,他们同时打开文件并将文件第一行读出来,加1写回去(将文件原有值覆盖掉)请保证20个任务线程完成后,文件中的第一行一定是20!

 

from threading import Thread

with open("text.txt", mode="w+") as f:
    f.write("0")

def thr():
    with open("text.txt", mode="r") as g:
        read = int(g.read())
        read += 1
        print(read)
    with open("text.txt", mode="w+") as h:
        h.write(str(read))

if __name__ == "__main__":
    for i in range(20):
        m = Thread(target=thr)
        m.start()
        m.join()

 

2.完成一个cs架构程序,服务端一旦接受到客户端请求文件路径后,判断此文件是否存在,如果存在,将文件内容发送给客户端,如果不存在,也请告知客户端.

3.求100~300之间的质数,四线程

以上是关于python20181223的主要内容,如果未能解决你的问题,请参考以下文章

20181223 Oralce中while

20181223 前端开发周报

20181223-信息系统基础知识

20181223何家豪 Exp7 网络欺诈防范

文件重命名时快速添加时间前缀

常用python日期日志获取内容循环的代码片段