如何解决正方形迭代器中的无限循环
class Squares:
def __init__(self,start,stop):
self.start = start
self.stop = stop
def __iter__(self):
return self
def __next__(self):
if self.start > self.stop:
raise stopiteration
else:
self.start = self.start ** 2
return self.start
for i in Squares(1,10):
print(i)
但是最后,通过执行上述代码,我们意识到从起点创建了一个无限循环,而next方法不能正确地控制迭代过程。
解决方法
将self.start
加1,然后返回其平方数:
class Squares:
def __init__(self,start,stop):
self.start = start
self.stop = stop
def __iter__(self):
return self
def __next__(self):
if self.start > self.stop:
raise StopIteration
else:
res = self.start ** 2
self.start = self.start + 1
return res
for i in Squares(1,10):
print(i)
出局:
1
4
9
16
25
36
49
64
81
100
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。