python3-开发面试题(python)6.23基础篇(2)详解编程语言

1、请至少列举5个 PEP8 规范(越多越好)。

一、代码编排

1、缩进。4个空格的缩进,不使用Tap,更不能混合使用Tap和空格

2、每行最大长度79,换行可以使用反斜杠,最好使用圆括号。换行点要在操作符的后边敲回车

二、文档编排

1、不要在一句import中多个库,比如import 欧式,sys

三、空格的使用

总体原则,避免不必要的空格

四、注释

1、总体原则,错误的注释不如没有注释,当一段代码发生变化时,第一件事就是要修改注释!

2、注释必须使用英文,最好是完整的句子,首字母要大写的。

3、避免无谓的注释

五、命名规范

类的方法第一个参数必须是self,而静态方法第一个参数必须是cls

遵循python的变量的命名规范。

六、编码建议

1、编码中考虑是他python实现的效率等问题,比如运算符‘+’在Jpython中效率却非常低,采用。join()的方式

2、字符串不要以空格收尾

3、使用startwith() and endswith() 代替切片进行序列前缀或后缀的检查

4、使用isinstance()比较对象的类型:

5、判断序列空与不空,if not 条件,优于if 条件 

2、通过代码实现如下转换:
二进制转换成十进制:v = “0b1111011”


int(v,2)     
十进制转换成二进制:v = 18


bin(v)
八进制转换成十进制:v = “011”


int(v,8)
十进制转换成八进制:v = 30


oct(v)
十六进制转换成十进制:v = “0x12”


int(v,16)

十进制转换成十六进制:v = 87

hex(v)

 

3、python递归的最大层数?

在pycharm中 递归的最大层数是1000次,无限制的递归调用自己是没有意义的

1、递归必须要有一个明确的结束条件

2、每次进入更深一层递归时,问题规模相比上次递归都有应有所减少

3、递归效率不高,递归层次过多会导致栈溢出

import sys 
sys.setrecursionlimit(递归的最大次数)

 

4、求结果:
v1 = 1 or 3


1
v2 = 1 and 3


3
v3 = 0 and 2 and 1

0

 v4 = 0 and 2 or 1

1

 v5 = 0 and 2 or 1 or 4

1


 v6 = 0 or Flase and 1

1

详细过程可以点击这里:https://www.cnblogs.com/ManyQian/p/9216815.html

5、ascii、unicode、utf-8、gbk 区别?

ascii  :   8bit=1bytes,一个英文字符占用1个字节  范围基本只有英文字母、数字和一些特殊字符,只有256个字符

gbk 编码汉字的: 16bit=2bytes  2个字节表示一个中文字节,1个字节表示英文字节

unicode全世界的所有字节(内存中固定的编码):16bit=2bytes,2个字节表示一个字符,中文也是2个字节

utf-8万国码:1字节表示一个英文字符,3bytes表示一个中文字符

6、字节码和机器码的区别?

字节码是一种中间码和二进制代码(文件),需要直译器转译后成为机器码

字节码:字节码通常指的是已经经过编译的源码,字节码的实现方式是通过编译器和虚拟机器

机器码:机器语言是一种指令集的体系,这种指令集就是机器码,是电脑cpu可以直接解读的数据

计算机可以直接执行,并且执行速度最快的代码

解释性语言:程序—》字节码—–》机器码  根据具体系统在编译为机器语言

编译型语言:程序—-》机器码    

7、三元运算规则以及应用场景?

三元运算符的功能与‘if …else’流程语句一致,它在一行中书写,代码非常精练,执行效率更高

嵌套使用的三元运算符可读性不太好,日后对代码的维护极可能存在问题

8、列举 Python2和Python3的区别?

1、print被视为一个语句而不是一个函数

2、整数的除法,2.7不直观

3、支持Unicode 2.7默认ASCII  3中默认Unicode

4、后续发展  2.7官方没有后续支持,3才是正统

 

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/12201.html

(0)
上一篇 2021年7月19日
下一篇 2021年7月19日

相关推荐

发表回复

登录后才能评论