一、概述
python中断言,这个我是第一次听说到的,断言有什么用呢?断言就是做一些程序的检查工作,就是在执行之前需要做的一些检查,比如类似于安检一样,合格的就能过,不合格的就不能过。也类似于银行转账工作,真正的转账之前是不是要检查用户各方面,是不是账号密码是不是都没有问题,转的钱必须没有问题,所以你在这个操作之前做一下检查。
二、知识点回顾
1、__new__方法:
先于__init__方法之前执行
2、__call__方法:
实例化之后加括号,去执行__call__方法
3、__metaclass__:
用来定义这个类是以怎样的形式被创建的
4、异常处理:
try: .... except (ValueError,KeyError),e # in 2.7写法 except (ValueError,KeyError) as e # in3.X写法 except Exception as e :放在异常最后,上面抓不到的异常全走这个 else: #没有异常发生时,执行 finally,无论如何都执行 raise ValueError : 抛出异常
5、断言:
下面单独讲
6、socket:
协议:tcp/ip send,recv
udp
地址簇(family address):
AF.INET ipv4
AF.INET6 ipv6
AF.UNIX local
协议类型(socket type protocol):
socket.SOCK_STREAM tcp/ip
socket.SOCK_DGRAM 数据格式socket,for UDP
服务端:
server = socket.socket(AF.INET,sock.SOCK_STREAM)server.bind((localhost,6969))server.listen()conn,addr = server.accept() #每当和客户端建立一个连接,就会生成一个实例,这个实例的值赋给conn,这边会产生阻塞while True: print("new conn",addr) data = conn.recv(1024) #官方推荐是8192,相当于8k if not data:break #客户端一断开,conn.recv收到的就都是空数据,就会进入死循环 print(data) conn.send(data.upper())
客户端:
client = socket.socket()clent.connect((serverip,6969))client.send(data)client.send(data)#这边可以发送多次data = client.recv(1024)
三、断言
作用:断言被用作你接下来的程序执行,如果后面程序依赖于前面的程序,后面的程序有很重要,就是后面的程序执行肯定不能出错,所以在执行之前要做检查工作。
3.1、断言关键字assert
class C(object): def __init__(self): self.name = "zhangqigao"c_obj = C()assert c_obj.name == "zhangqigao" #断言print("没有错误继续...")#输出没有错误继续...
3.2、断言出错
class C(object): def __init__(self): self.name = "zhangqigao"c_obj = C()assert c_obj.name == "gaogao" #断言出字符串不匹配print("没有错误继续...")#输出Traceback (most recent call last): File "E:/PycharmProjects/pytest/day7/断言.py", line 10, inassert c_obj.name == "gaogao"AssertionError #报断言异常错误
当然我们用我们之前的知识也是可以解决上面的问题,代码如下:
class C(object): def __init__(self): self.name = "zhangqigao"c_obj = C()if c_obj.name == "gaogao": print("有错误....")else: print("没有错误继续...")
但是这个不仅增加了代码量,而且感觉还是比较low,这个就相当于你开着五菱之光的车,和开着特斯拉的区别。