本帖最后由 逃兵 于 2021-3-11 14:09 编辑
stack是通过遍历start得到的
我们改一下类
让stack直接赋值
- class Stack:
- def __init__(self, start=[]):
-
- self.stack = start
- def isEmpty(self):
- return not self.stack
-
- def push(self, obj):
- self.stack.append(obj)
- def pop(self):
- if not self.stack:
- print('警告:栈为空!')
- else:
- return self.stack.pop()
- def top(self):
- if not self.stack:
- print('警告:栈为空!')
- else:
- return self.stack[-1]
- def bottom(self):
- if not self.stack:
- print('警告:栈为空!')
- else:
- return self.stack[0]
- start=[]
- a=Stack(start)
- print('a对象属性 %s'% a.stack)
- start.append(1)
- print('列表的元素 %d'% start[0])
- print('a对象的属性 %s'% a.stack)
复制代码
为什么原答案要以遍历的方式赋值呢,原因在于参数start是个列表,列表是个可变数据
如果用直接赋值的方式,在外部改变列表start就会影响到类的实例,可能引发我们意料之外的bug
所以用遍历的方式赋值,避免因修改start而引发的问题