我有一个带链表的堆栈。当我调用list.push()
时,它工作得很好,但当我在函数init()
中执行相同操作时,它什么也不做。可能是什么问题?
class Node:
def __init__(self, data):
self.data = data
self.nextNode = None
def __str__(self):
return str(self.data)
class linkedList:
def __init__(self):
self.head = None
self.end = None
def isEmpty(self):
return self.head == None
def push(self, item):
new_node = Node(item)
if not self.head:
self.head = self.end = new_node
else:
new_node.nextNode = self.head
self.head = new_node
#doesnt work
def init():
list = linkedList()
list.push("a")
init()
print(list.isEmpty()) #True
#works
list = linkedList()
list.push("a")
print(list.isEmpty()) #False
在函数外部,您无法访问在函数内部创建的本地对象。返回使其可用:
def make_list():
my_list = linkedList()
my_list.push("a")
return my_list
my_list = make_list()
print(my_list.isEmpty())
不要为对象使用名称list
,因为它会遮挡内置的list
。
您需要RETURN您在函数中创建的对象,因为当函数结束时,对象"将死亡",因此没有对象可供您查看。这就是为什么你会变得空洞真实。
以下是如何使其发挥作用:
def make():
aList = linkedList()
aList.push("a")
return aList
然后您将存储从该对象返回的任何东西:
some_list = make() # storing the linkedlist that make() returns into
# variable called 'some_list'
print(some_list.isEmpty()) # True