c++ 计时器_CSDN第二个Ptython 作业 1.类实现一个计数器 2.自定计时器装饰器

作业1:

通过本周学习的内容,自主设计编写一个Student类,能够统计学生人数.

作业体现形式:

以代码的方式保存成后缀为py的脚本.

作业的注意事项:

1.文件名命名规范.

2.注释清晰.

3.运行结果符合预期效果 .

思路提示:

1.使用Python的class 类的相关模块去实现文件.

2.给Student类增加一个类属性,每创建一个实例,该属性自动增加+1.

作业内容:

  1. #! /usr/bin/python3
  2. # ! -*- coding:utf-8 -*-
  3. '''
  4. 为了统计学生人数,可以给Student类增加一个类属性,每创建一个实例,该属性自动增加
  5. '''
  6. class Student(object):
  7. # 定义类变量
  8. count = 0 # 计数,每创建一个对象就加1
  9. # 初始化变量
  10. def __init__(self, name):
  11. self.name = name
  12. # 每实例化一个学生,就调用一次 count_sum方法,使类变量count+=1
  13. self.count_sum()
  14. def count_sum(self):
  15. Student.count += 1
  16. if __name__ == '__main__':
  17. # 实例化Student类
  18. a = Student('lisi')
  19. b = Student('wangwu')
  20. c = Student('zhaoliu')
  21. d = Student('maqi')
  22. e = Student('liuba')
  23. print('共创建学生:{}个'.format(Student.count))

测试运行结果:

ab87e613097ad531772c99cb06e1cfe8.png

作业2:

通过本周学习的内容,自主编写设计一个装饰器,它可以作用于任何函数上,打印函数的执行时间.

作业体现形式:

以代码的方式保存成后缀为py的脚本.

作业的注意事项:

1.文件名命名规范.

2.注释清晰.

3.运行结果符合预期效果 .

思路提示:

1.装饰器的简单理解:实际上就是为了给一个程序添加额外的功能,但是该程序已经上线或者已被使用,那么就不能大批量的修改源码,这样不现实,因此就产生了装饰器的概念。

2.函数的传递参数:*args, **kwargs 代表函数可以接受所有类型所有格式的参数.

3.引入datetime,time模块来计算函数的运行时间和时间格式的转化.

作业内容:

  1. #! /usr/bin/python3
  2. # ! -*- coding:utf-8 -*-
  3. '''
  4. 设计一个装饰器,它可以作用于任何函数上,打印函数的执行时间
  5. '''
  6. import datetime
  7. import time
  8. def metric(func):
  9. '''自定义计时装饰器'''
  10. # *args, **kwargs 代表该方法可以接受所有类型所有格式的参数。
  11. def wrapper(*args, **kwargs):
  12. # 计算函数开始的时间
  13. start = datetime.datetime.now()
  14. # 调用传入的函数方法
  15. func(*args, **kwargs)
  16. # 计算函数结束的时间
  17. end=datetime.datetime.now()
  18. # 计算函数运行所用的时间
  19. times=end-start
  20. # 将算出来的函数进行格式的转化和输出.
  21. print("%s 执行耗时 %f 秒" % (func.__name__,times.total_seconds())) #time是datetime.timedelta类型,后六位是微秒
  22. # 这里的return可以理解为 调用装饰器以后,返回wrapper方法,相当于将测试用的mysum方法当做参数传到wapper中进行调用.
  23. return wrapper
  24. '''
  25. 装饰器的调用方式:在调用的函数前边使用 @装饰器 的方式,使装饰器生效.
  26. '''
  27. @metric
  28. # 定义测试函数,测试自定义的计时器是否生效.
  29. def mysum():
  30. lista = [x for x in range(1000000)]
  31. time.sleep(3)
  32. if __name__ == '__main__':
  33. # 调用函数,测试结果.
  34. mysum()

测试运行结果:

f304737ece230dbbc6e4028fd1fcd794.png
4bcf2ac2aa3eae2f26fc541293e69a71.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值