鱼C论坛

 找回密码
 立即注册
查看: 2314|回复: 3

[已解决]小白

[复制链接]
发表于 2021-3-30 17:07:21 | 显示全部楼层 |阅读模式
5鱼币
while True:
    if not len(fish):
        print("鱼儿都吃完了,游戏结束!")
        break
    if not turtle.power:
        print("乌龟体力耗尽,挂掉了!")
        break

    pos = turtle.move()
    # 在迭代器中删除列表元素是非常危险的,经常会出现意想不到的问题,因为迭代器是直接引用列表的数据进行引用
    # 这里我们把列表拷贝给迭代器,然后对原列表进行删除操作就不会有问题了^_^
    for each_fish in fish[:]:                      #为何要进行切片,而不是for each_fish in fish:
        if each_fish.move() == pos:
            # 鱼儿被吃掉了
            turtle.eat()
            fish.remove(each_fish)
            print("有一条鱼儿被吃掉了...")

最佳答案
2021-3-30 17:07:22
huangdongdong 发表于 2021-3-30 22:39
为何fish[:]就是把列表拷贝给迭代器

a = fish[:]  
for each_fish in a:
   

最佳答案

查看完整内容

a = fish[:] for each_fish in a:
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-3-30 17:07:22 | 显示全部楼层    本楼为最佳答案   
huangdongdong 发表于 2021-3-30 22:39
为何fish[:]就是把列表拷贝给迭代器

a = fish[:]  
for each_fish in a:
   
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-3-30 20:46:55 | 显示全部楼层
# 在迭代器中删除列表元素是非常危险的,经常会出现意想不到的问题,因为迭代器是直接引用列表的数据进行引用
    # 这里我们把列表拷贝给迭代器,然后对原列表进行删除操作就不会有问题了^_^


for each_fish in fish[:]   fish[:]    把列表拷贝一份给迭代器
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-3-30 22:39:45 | 显示全部楼层
ba21 发表于 2021-3-30 20:46
# 在迭代器中删除列表元素是非常危险的,经常会出现意想不到的问题,因为迭代器是直接引用列表的数据进行 ...

为何fish[:]就是把列表拷贝给迭代器
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-9 16:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表