2017.11.20 装饰器

说下对python深浅拷贝的理解。并有代码简单实现

浅拷贝是对于一个对象的顶层拷贝,通俗的理解是:拷贝了引用,并没有拷贝内容

copy.copy

内层地址一样

外层地址:

1、如果是可变,地址不同

2、如果是不可变,地址相同

深拷贝是对于一个对象所有层次的拷贝(递归)

只有一层深浅拷贝没区别:都是

1、如果是可变,地址不同

2、如果是不可变,地址相同

copy.deepcopy

1、如果所有层都是不可变的,所有层地址相同

2、如果有一个可变的,外层一定不同

3、如果内层中这一层是可变的,地址不同。否则,地址相同

二者地址一样,指向同一个

a = [1,2,3]

b = a

a.append(4)

a = [1,2,3,4]b = [1,2,3,4]

id相同

a = [1,2,3]

b = coop.deepcooy(a)

a.append(4)

a = [1,2,3,4]b = [1,2,3]

id不同

2.简答

说下对生成器的理解,有几种创建方式,并用代码简单实现。

如果数据量比较大,想办法以某种算法,进行推算出数据。将推算的算法保存起来,以后通过算法计算出下一个数据,这样就避免了一次性占用过多内存

在Python中,这种一边循环一边计算的机制,称为生成器:generator

可以通过next()函数获得生成器的下一个返回值

要创建一个生成器,有三种方法。

1把一个列表生成式的[ ]改成( ),列表生程式

ge1=(i for i in range(0,100,5))

print(next(ge1))

for i in ge1:

print(i)

2、在方法中使用yield形式保存算法

def fib(num):

a,b = 0,1

while num>1:

print('1....')

yield b  #返回值前面加yield

print('2.....')

a,b = b,a+b

num-=1

print('3....')

ge = fib(300)

print(ge)  #第一次调用函数时,发现yield,不执行,返回一个对象地址

print(next(ge))  #通过next获取生成器中保存算法的每一个值

print(next(ge))

print(next(ge))

print(next(ge))

print(next(ge))

print(next(ge))

3.简答

说下对迭代器的理解,并用代码简单实现。

迭代器是一个可以记住遍历的位置的对象。迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。可以被next()函数调用并不断返回下一个值的对象称为迭代器:Iterator。

可以使用isinstance()判断一个对象是否是Iterator对象.

from collections import Iterable,Iterator

def f():

yield 'hello'

print(isinstance(f(),Iterable))

print(isinstance(f(),Iterator))

print(isinstance('abc',Iterable))

print(isinstance('abc',Iterator))

name = 'abc'

myIter = iter(name)

print(type(myIter))

print(isinstance(myIter,Iterator))

try:

print(next(myIter))

print(next(myIter))

print(next(myIter))

print(next(myIter))

print(next(myIter))

print(next(myIter))

except StopIteration as ex:

print('迭代完了,%s'%ex)

4.简答

说下对装饰器的理解,并用代码简单实现。

写代码要遵循开放封闭原则,虽然在这个原则是用的面向对象开发,但是也适用于函数式编程,简单来说,它规定已经实现的功能代码不允许被修改,但可以被扩展,即:

封闭:已实现的功能代码块

开放:对扩展开发

@函数名 是python的一种语法糖。

def outer(func):

print('outer...')

def inner():

ret = input('洗手了吗?')

if ret == 'yes':

func()

else:

print('洗手去')

return inner   #加小括号是调用函数,执行程序

@outer   #原函数

def myFunc1():    #myFunc1这个名字指向

print('吃饭....')

@outer

def myFunc2():

print('睡觉....')

myFunc1()

# decorate = outer(myFunc)

# print(decorate)   #decorate指向返回值outer里的innner

# print('**********************')

# decorate()

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 包(lib)、模块(module) 在Python中,存在包和模块两个常见概念。 模块:编写Python代码的py...
    清清子衿木子水心阅读 9,212评论 0 27
  • 迭代器和生成器 楔子 假如我现在有一个列表l=['a','b','c','d','e'],我想取列表中的内容,有几...
    go以恒阅读 4,099评论 1 4
  • 小小的探索了一下简书markdown 献给写作者的 Markdown 新手指南 探索新发现 六个空格进入代码模式:...
    _时间滴答阅读 3,775评论 0 2
  • 今晚听李志听哭 也是很里程碑了 以及男人都真的是狗吧 也真是无语
    白糖蛋黄阅读 1,085评论 0 0
  • 无意中在书里看到一句话,浅青色的黎明,风把天刮净了,几颗小星星,弯刀一样的月亮,斜钉在天上。 这几句话,只是普通的...
    无名氏星球阅读 1,720评论 0 3

友情链接更多精彩内容