JavaScript 网红太空人表盘 引言: 之前我有用Java写过一个飞机大战,感觉挺受欢迎的,有的小伙伴想用Javasript写,我这次就按我的思路写了一个JS版本。...boom.wav" > 添加画布 在plane.js编写代码 创建函数 function Plane(){ this.renderArr=[];//渲染数组 this.renderArr2...='start'){ clearInterval(bullet.timmer); } bullet.dy-=20; if
创建一个装饰器 import time def timmer(func): """ :param func: 被装饰的函数 :return: 一个计算函数运行时间的函数...stop_time-start_time)) return result return wrapper 使用装饰器 def add(x, y): print(x,y) # 因为timmer...返回的是wrapper函数对象,所以执行add()相当于执行wrapper() add = timmer(add) add(1,2) 如果觉得还是麻烦那就通过一个语法糖@符号来使用装饰器 @timmer...y): print(x,y) add(1,2) 这就是最基本的装饰器, 在不修改源代码的前提下为函数添加一个新功能, 调用时只需要在原函数上方添加一个 @deco_name , 在这里是@timmer...---- 带参数的装饰器 python还允许我们给装饰器带上函数 import time def timmer(flag): """ :param flag: 接收装饰器的参数
#等同于 index=timmer(index) , 此后index等同于 wrapper def index(): time.sleep(1)...wen run time is 1.0001096725463867 函数timmer就是装饰器,它把执行真正业务方法的func包裹在函数里面,看起来像index被timmer装饰了。...3、装饰器的语法 @timmer timmer就是一个装饰器 @timmer等同于 被装饰函数名=timmer(被装饰函数名) 被装饰器函数就是紧接@timmer下面的函数 4、无参装饰器 如果多个函数拥有不同的参数形式...无参装饰器,被装饰函数带参,无返回值 1 2 3 4 5 6 7 8 9 10 import time def timmer...(func): def wrapper(*args,**kwargs): print(func) return wrapper @timmer
stop_time=time.time() print('运行时间是%s' %(stop_time-start_time)) return wrapper @timmer...#语法糖,这个是重点 def test(): time.sleep(3) print('test函数运行完毕') # res=timmer(test) #返回的是wrapper的地址...# res() #执行的是wrapper() # test=timmer(test) #返回的是wrapper的地址 # test() #执行的是wrapper() test() ''' 语法糖...''' # @timmer #就相当于 test=timmer(test) 3、函数闭包加上返回值 #未加返回值 import time def timmer(func): def wrapper...time.time() print('运行时间是%s' %(stop_time-start_time)) return 123 return wrapper @timmer
print('今天好热') # result = timmer(func) @timeer与此句一个作用相同 func() # 分析一下,此func等价于timmer(func),也就相当于inner...print('今天好热',a) # result = timmer(func) @timeer与此句一个作用相同 func(1) # 分析一下,此func等价于timmer(func),也就相当于inner...print('今天好热',a,b) # result = timmer(func) @timeer与此句一个作用相同 func(1,b = 3) # 分析一下,此func等价于timmer(func)...import time Flag = False def timmer_out(Flag): def timmer(func): def inner(*args,**kwargs...@timmer_out(Flag) def para_fir(): time.sleep(0.1) print('the first') @timmer_out(Flag) def
def func(): print('嘻嘻更健康') def timmer(f): start_time = time.time() time.sleep(0.1) f(...好,你又进一步改,如下 func() f1 = func # func func = timmer # timmer func(f1) 将他的执行结果改了一下,这样看似func(f1)与原来的调用差不多...(func) # inner func() # inner() 这样,就写好了,这是最简单的装饰器,装饰任何函数,只需要加一句func = timmer(func) 肯定有人在想,这一堆鬼东西是什么啊...,慢 别急往下看.兄弟我说的是往下看文章,不是看你下边 func函数是小刚,timmer函数是小花,inner函数是小红.小花和小红是非常好的闺蜜 小刚对小红一直暗生情愫,直到有一天憋不住了想和小红说但是...#简单的装饰器 def func(): print('嘻嘻更健康') def timmer(f): def inner(): start_time = time.time
_, (time_e - time_b))) return wrapper # 注意这个return的位置 # 写在装饰的函数的前面,装饰多个函数,每个函数前面需加上@decorator @timmer... # test = timmer(test) = wrapper, 调用时test() = wrapper(),这里说明参数的传输问题 # test(*args,**kv) = wrapper(*args... # test = timmer(test) = wrapper, 调用时test() = wrapper(),这里说明参数的传输问题 # test(*args,**kv) = wrapper(*args...''' def login(login_type): def timmer(func): #@functools.wraps(func) def wrapper(...__name__, (time_e - time_b))) return wrapper # 注意这个return的位置 return timmer # 注意这个return的位置
/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import time 4 def timmer(func): 5 def wrapper(.../usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import time 4 def timmer(func): #func=test1 5...#test=timmer(test) 16 17 def test(name,age): 18 time.sleep(3) 19 print('test函数运行完毕,名字是【%s】...res=timmer(test) #返回的是wrapper的地址 20 # res() #执行的是wrapper() 21 22 # test=timmer(test) #返回的是wrapper...的地址 23 # test() #执行的是wrapper() 24 25 # @timmer 就相当于 test=timmer(test) 8.验证功能装饰器 1 #!
) def home(name): print('welcome %s to home page' %name) time.sleep(2) return 123 def timmer...(index) index() home=timmer(home) res=home('zls') print(res) ---- 装饰器语法糖 import time def timmer(func...def index(): print('welcome to index page') time.sleep(3) # 语法糖,把装饰器,放到被装饰对象上面加上@ @timmer def...def index(): print('welcome to index page') time.sleep(3) index() 叠加多个装饰器 import time def timmer...疯了吧 所以我们需要记录一下用户的登录状态... import time current_user={'username':None} def timmer(func): def wrapper
%(stop_time-start_time)) return res #返回被装饰函数的返回值 return wrapper #返回装饰函数wrapper的内存地址 @timmer... #同test1=timmer(test1); # 理解:执行timmer(test1),得到返回值wrapper内存地址,再把wrapper内存地址赋值给test1 def...test1(): time.sleep(1) print("my name is test1") return "test1" @timmer #同test2=timmer(test2)...(1) print("my name is %s,I'm %s" %(name,age)) test1() #要配合上面@timmer使用,同timmer(test1)() print(test1...()) test2("chen",40) #要配合上面@timmer使用,同timmer(test2)("chen",40) print(test2("chen",40)) #结果 my name
如果被装饰的函数有返回值 def timmer(func): def wrapper(*args,**kwargs): start_time = time.time()...像home = timmer(home)这样的写法,python给我们提供了一个便捷的方式------语法糖@. ...以后我们再要在被装饰的函数之前写上@timmer,它的效果就和home = timmer(home)是一样的。 如果一个函数被多个装饰器装饰,那么执行顺序是怎样的。...import time import random def timmer(func): def wrapper(): start_time = time.time()...(index)) @timmer # index = timmer(index) def index(): time.sleep(3) print(
(index) # index() #装饰器语法:@装饰器名 # import time # # def timmer(func): # def inner(): # start...下面的函数名当成参数传给timmer这个函数,并且把结果重新命名给index # @timmer #index=timmer(index) # def index(): # time.sleep...#index=timmer(index) # def index(): # time.sleep(3) # print('welcome to index') # return...111 # # res=index() # print(res) #装饰器改进2 #这个改进解决了传参问题 # import time # # def timmer(func): # def...__name__ return inner @timmer def index(name): #index=inner '''index 函数。。。。。'''
装饰器的框架 def timmer(func): def wrapper(): print(func) func() return wrapper() 装饰器实现.../usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import time 4 def timmer(func): #func=test 5 def...print('运行时间是%s' %(stop_time-start_time)) 11 return res 12 return wrapper 13 14 @timmer...#test=timmer(test) 要修饰哪个函数就在哪个函数前加 15 def test(name,age,gender): 16 time.sleep(3) 17 print(
不修改被装饰对象的调用方式 装饰器的目标:在遵循1和2的前提下,为被装饰对象添加上新功能 三 装饰器的使用 下面是为一个函数添加装饰器,添加了计算其运行时间的功能: 1 import time 2 def timmer...print('run time is %s' %(stop_time-start_time)) 8 return res 9 return wrapper 10 11 @timmer
一般草根团队在PoC阶段凑和用的, 我们微信极光公众号激活宝这个产品, 开发这个功能的时候, 已经积累了非常多的用户量, 这里显然不合适, 所以pass掉了 [image.png] 使用golang defer timmer...所以虽然实现起来超级简单, 但可用性没达标, 最后pass 使用Linux时间轮 golang defer timmer的底层是linux时间轮, 为了解决分布式的本质问题, 研究了时间轮的实现....delayed-messages.html https://wxjiguang.com 本文连接 https://www.wxjiguang.com/blog/how-to-push-message-with-timmer-after-user-subscribed-in-wechat-official-account
(index) index() # 版本三就是最简单的一个装饰器,在不改变原函数的源码以及调用方式的前提下,为其增加额外的功能,测试执行效率 # 装饰器一定要在代码的最上面 def timmer(...(index)可以使用下面这种方式 # @装饰器名, 语法糖 # @timmer = index = timer(index) @timmer def index(): time.sleep(...1) print("欢饮访问博客园主页") @timmer def home(name): time.sleep(2) print(f'欢迎访问{name}主页') index...() 带返回值的装饰器 def timmer(func): def inner(): start_time = time.time() result = func...time.sleep(2) print(f'欢迎访问{name}主页') # ret = index('幽梦') # print(ret) @timmer def demo1(name,age
green() { console.log('green');}function yellow() { console.log('yellow');}var light = function (timmer...resolve, reject) { setTimeout(function () { cb(); resolve(); }, timmer...;}));first().then((arg) => { console.log(arg);});console.log(4);解析这道题就其实和 Promise 的关系不太大,主要是需要理解 JS...执行机制,才能很好的解决这道题,对于 JS 执行机制不了解的朋友推荐看看这篇文章这一次,彻底弄懂 JavaScript 执行机制第一轮事件循环先执行宏任务,主script ,new Promise立即执行
green'); } function yellow() { console.log('yellow'); } var light = function (timmer...setTimeout(function () { cb(); resolve(); }, timmer...((arg) => { console.log(arg); }); console.log(4); 解析 这道题就其实和 Promise 的关系不太大,主要是需要理解 JS...执行机制,才能很好的解决这道题,对于 JS 执行机制不了解的朋友推荐看看这篇文章 这一次,彻底弄懂 JavaScript 执行机制 第一轮事件循环 先执行宏任务,主script ,new Promise
console.log('green'); } function yellow() { console.log('yellow'); } var light = function (timmer...resolve, reject) { setTimeout(function () { cb(); resolve(); }, timmer...first().then((arg) => { console.log(arg); }); console.log(4); 解析 这道题就其实和 Promise 的关系不太大,主要是需要理解 JS...执行机制,才能很好的解决这道题,对于 JS 执行机制不了解的朋友推荐看看这篇文章 这一次,彻底弄懂 JavaScript 执行机制 第一轮事件循环 先执行宏任务,主script ,new Promise
领取专属 10元无门槛券
手把手带您无忧上云