In diesem Kapitel werden wir mehr über Kontrollstrukturen in Ruby sprechen.
Fall
Wir verwenden den case -Operator, um auf eine Folge von Bedingungen zu testen. Dies ist in der Tat sehr ähnlich zu switch in C und Java, aber leistungsfähiger, wie wir gleich sehen werden.
ruby> i=8 ruby> case i | when 1, 2..5 | print "1..5\n" | when 6..10 | print "6..10\n" | end 6..10 nil
2..5 ist ein Ausdruck, der einen Bereich zwischen 2 und 5 bedeutet, einschließlich. Der folgende Ausdruck prüft, ob i in diesem Bereich liegt:
(2..5) === i
case verwendet intern die Beziehung mit dem Operator ===, um mehrere Bedingungen gleichzeitig zu testen. Um die objektorientierte Natur von Ruby beizubehalten, wird der ===-Operator in Abhängigkeit von dem verglichenen Objekt mit der Bedingung im when -Operator interpretiert. Der folgende Code vergleicht beispielsweise Zeichenfolgen in der ersten when-Anweisung und mit einem regulären Ausdruck in der zweiten when -Anweisung.
ruby> case 'abcdef' | when 'aaa', 'bbb' | print "aaa or bbb\n" | when /def/ | print "includes /def/\n" | end includes /def/ nil
während
Ruby bietet mehrere Möglichkeiten, Regelschleifen zu erstellen, obwohl Sie im nächsten Kapitel erfahren werden, wie Sie Iteratoren verwenden, damit Sie nicht zu oft reguläre Schleifen verwenden.
While ist ein wiederholbares if. Wir haben diese Schleife in Programmen für Rätsel und reguläre Ausdrücke verwendet (siehe vorheriges Kapitel ). Diese Schleife besteht also aus der while, -Anweisung der Schleifenkörperbedingung und der end. -Anweisung. Der Schleifenkörper wird verarbeitet, solange die Bedingung true zurückgibt. while kann jedoch problemlos auf einzelne Codezeilen angewendet werden, und dann ist die end -Anweisung nicht erforderlich.
ruby> i = 0 0 ruby> print "It's zero.\n" if i==0 It's zero. nil ruby> print "It's negative.\n" if i<0 nil ruby> print "#{i+=1}\n" while i<3 1 2 3 nil
Manchmal möchten Sie vielleicht einen negativen Test verwenden. unless ist das Gegenteil von if und until ist das Gegenteil von while. Wir überlassen es Ihnen, mit diesen Anweisungen zu experimentieren.
Es gibt mehrere Möglichkeiten, den Durchgang der Schleife von innen zu unterbrechen. Zuerst break , was die gleiche Bedeutung wie in C hat, um aus einer Schleife auszubrechen. Zweitens, next , um die nächste Iteration der Schleife zu starten (in C ist es continue ). Drittens hat Ruby Redo, wodurch die aktuelle Iteration neu gestartet wird. Der folgende C-Code veranschaulicht die Bedeutung von break, next und redo.
while (condition) { label_redo: goto label_next; /* ruby's "next" */ goto label_break; /* ruby's "break" */ goto label_redo; /* ruby's "redo" */ ... ... label_next: } label_break: ...
Die vierte Möglichkeit, die Schleife zu verlassen, ist die return, -Anweisung innerhalb der Schleife. Aber das Ausführen von return bewirkt nicht nur das Verlassen der Schleife, sondern auch das Verlassen der Methode, die diese Schleife enthält. Wenn ein Argument angegeben wird, gibt der Operator den Wert der aufgerufenen Methode zurück, andernfalls wird nil. zurückgegeben.
Pro
C-Programmierer werden daran interessiert sein zu erfahren, wie die for -Schleife verwendet werden kann. Ruby macht das ein wenig interessanter. Die folgende Schleife wird jedes Mal für jedes Element in der Sammlung ausgeführt:
for elt in collection ... end
Eine Sammlung kann eine Reihe von Werten sein (das meinen die meisten Leute, wenn sie von einer Schleife sprechen):
ruby> for num in (4..6) | print num,"\n" | end 4 5 6 4..6
Es kann eine Sammlung anderer Art sein, z. B. ein Array:
ruby> for elt in [100,-9.6,"pickle"] | print "#{elt}\t(#{elt.type})\n" | end 100 (Fixnum) -9.6 (Float) pickle (String) [100, -9.6, "pickle"]
Aber wir greifen uns ein wenig vor. for hat eine andere Schreibweise mit der each -Methode, wie sich herausstellt, und die wir in unserem ersten Iterator-Beispiel behandeln werden. Die folgenden beiden Formen sind gleichwertig:
# Если вы использовали C или Java, то предпочитаете скорее всего такой стиль for i in collection ... end # Smalltalk программисты могут предпочитать такой стиль collection.each {|i| ... }
Iteratoren können oft durch entsprechende Schleifen ersetzt werden, aber sobald Sie anfangen, sie zu verwenden, werden Sie feststellen, dass sie wirklich einfacher zu handhaben sind.