如何模拟 do-while 循环?

55 浏览
0 Comments

如何模拟 do-while 循环?

我需要在 Python 程序中模拟一个 do-while 循环。不幸的是,下面这个直接的代码不起作用:

list_of_ints = [ 1, 2, 3 ]
iterator = list_of_ints.__iter__()
element = None
while True:
  if element:
    print element
  try:
    element = iterator.next()
  except StopIteration:
    break
print "done"

它并不会输出 \"1,2,3,done\",而是输出以下内容:

[stdout:]1
[stdout:]2
[stdout:]3
None['Traceback (most recent call last):
', '  File "test_python.py", line 8, in 
    s = i.next()
', 'StopIteration
']

我应该怎么做才能捕捉到 \"stop iteration\" 异常并正确地跳出循环呢?

下面的伪代码展示了为什么可能需要这样做的示例。

状态机:

s = ""
while True :
  if state is STATE_CODE :
    if "//" in s :
      tokens.add( TOKEN_COMMENT, s.split( "//" )[1] )
      state = STATE_COMMENT
    else :
      tokens.add( TOKEN_CODE, s )
  if state is STATE_COMMENT :
    if "//" in s :
      tokens.append( TOKEN_COMMENT, s.split( "//" )[1] )
    else
      state = STATE_CODE
      # Re-evaluate same line
      continue
  try :
    s = i.next()
  except StopIteration :
    break

admin 更改状态以发布 2023年5月23日
0
0 Comments

这里有一种非常简单的方式来模拟 do-while 循环:

condition = True
while condition:
    # loop body here
    condition = test_loop_condition()
# end of loop

do-while 循环的主要特点是循环体至少执行一次,并且条件在循环体底部进行评估。这个控制结构可以实现这两个特点,而不需要异常或中断语句。它会引入一个额外的布尔变量。

0
0 Comments

我不确定你尝试做什么。你可以像这样实现一个do-while循环:

while True:
  stuff()
  if fail_condition:
    break

或者:

stuff()
while not fail_condition:
  stuff()

你想使用do while循环打印列表中的内容吗?为什么不直接使用:

for i in l:
  print i
print "done"

更新:

那么你有一些行的列表吗?你想一直迭代它吗?怎么样:

for s in l: 
  while True: 
    stuff() 
    # use a "break" instead of s = i.next()

这似乎接近你想要的东西了吗?使用你的代码示例,它将是:

for s in some_list:
  while True:
    if state is STATE_CODE:
      if "//" in s:
        tokens.add( TOKEN_COMMENT, s.split( "//" )[1] )
        state = STATE_COMMENT
      else :
        tokens.add( TOKEN_CODE, s )
    if state is STATE_COMMENT:
      if "//" in s:
        tokens.append( TOKEN_COMMENT, s.split( "//" )[1] )
        break # get next s
      else:
        state = STATE_CODE
        # re-evaluate same line
        # continues automatically

0