1 / 22

More Perl Control Flow

More Perl Control Flow. Learning Objectives: To learn more commands for control flow To apply the new commands learnt for writing tidier program To understand the limitation of using some control flow statements. Perl Arrays and Lists. Table of Content Control Flow Unless Until

terrel
Télécharger la présentation

More Perl Control Flow

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. More Perl Control Flow Learning Objectives: To learn more commands for control flow To apply the new commands learnt for writing tidier program To understand the limitation of using some control flow statements

  2. Perl Arrays and Lists Table of Content • Control Flow • Unless • Until • do … while • do … until • foreach • foreach $_ • “last” again • Next • Redo • Next & redo • Redo & last/next • Labeled Blocks • Labeled Blocks Examples • Backward if • Backward unless, while, until • && if • || unless

  3. Control Flow • We have already seen several Perl control flow statements: • if • while • for • last • Other control flow statements: • unless • until • do while • do until • foreach • next • redo

  4. “ unless “ statement (1) • The Perl unless statement is like an if statement with the condition negated: if($temperature <= 20){ print "too cold!\n"; } unless($temperature > 20){ # same thing print "too cold!\n"; } ------------------------------------------- if(!$hot){ print "too cold!\n"; } unless($hot){ # same thing print "too cold!\n"; }

  5. “ unless “ statement (2) • unless can have else, just like if: #!/usr/local/bin/perl5 -w print "Enter temperature: "; chomp($temperature = <STDIN>); unless($temperature > 20){ print "too cold!\n"; }else{ print "too hot!\n"; }

  6. “ unless “ statement (3) • unless can also have elsif, just like if: #!/usr/local/bin/perl5 -w print "Enter temperature: "; chomp($temperature = <STDIN>); unless($temperature >= 20){ print "too cold!\n"; }elsif($temperature == 20){ print "ok!\n"; }else{ print "too hot!\n"; }

  7. “ until “ statement (1) • The Perl until statement is like an while statement with the condition negated. • Sometimes is is easier to say “until something is true” rather than “while not this is true”: while(!$endoffile){ ... } until($endoffile){ # same thing ... }

  8. “ until “ statement (2) • The untilstatement loops indefinitely, until the condition is true, such as a user-controlled condition: #!/usr/local/bin/perl5 -w $resp = "no"; until($resp eq "yes"){ print "Wakeup [yes/no]? "; chomp($resp = <STDIN>); } $ test11 Wakeup [yes/no]? no Wakeup [yes/no]? y Wakeup [yes/no]? yes $

  9. “ do … while “ statement (1) • The do whilestatement is like the C++ do while statement. • It loops indefinitely, while the condition is true, such as a user-controlled condition: • do while always executes the body of the loop at least once. #!/usr/local/bin/perl5 -w do{ print "Wakeup [yes/no]? "; chomp($resp = <STDIN>); }while($resp ne "yes"); $ test11 Wakeup [yes/no]? no Wakeup [yes/no]? yes $

  10. “ do … until “ statement (1) • The do untilstatement loops indefinitely, until the condition is true, such as a user-controlled condition. • do until always executes the body of the loop at least once. #!/usr/local/bin/perl5 -w do{ print "Wakeup [yes/no]? "; chomp($resp = <STDIN>); }until($resp eq "yes"); $ test11 Wakeup [yes/no]? no Wakeup [yes/no]? y Wakeup [yes/no]? yes $

  11. “ foreach “ statement (1) • foreach takes a list of values and assigns them one by one to a scalar variable. • The body of the loops is executed once for each successive assignment. • foreach is similar to the shell programming’s for statement. foreach $i (@some_list){ ... }

  12. “ foreach “ statement (2) • The following example sums the contents of an array: $ cat sum #!/usr/local/bin/perl5 -w @a = (21,32,3,44,75,16,19); $sum = 0; foreach $b (@a){ $sum += $b; } print "The array sum is: $sum\n"; $ sum The array sum is: 210 $

  13. “ foreach “ statement (3) • foreach allows us to easily print an array in our own customized way. • The following example prints an array with each element separated by 2 spaces: $ cat print1 #!/usr/local/bin/perl5 -w @a = (1,2,3,4,5); foreach $i (@a){ print "$i "; } print "\n"; $ print1 1 2 3 4 5 $

  14. “ foreach “ statement (4) • The following example prints the numbers in reverse order without changing the array: $ cat print2 #!/usr/local/bin/perl5 -w @a = (1,2,3,4,5); foreach $i (reverse @a){ print "$i "; } print "\n"; $ print2 5 4 3 2 1 $ • reverse @a is the same as writing reverse(@a). Parenthesis are always optional on Perl functions.

  15. “ foreach “ statement (5) • If you omit the scalar variable in foreach, Perl will use $_ automatically: $ cat print3 #!/usr/local/bin/perl5 -w @a = (1,2,3,4,5); foreach (reverse @a){ print; } print "\n"; $ print3 54321 $ • print (and other Perl functions) use $_ as the default if nothing is specified.

  16. “ foreach “ statement (6) • Of course, if you want double spaces, you will have to use $_ explicitly: $ cat print3a #!/usr/local/bin/perl5 -w @a = (1,2,3,4,5); foreach (reverse @a){ print "$_ "; } print "\n"; $ print3a 5 4 3 2 1 $

  17. “ foreach “ statement (7) • The scalar variable in foreach is an alias for each variable in the list, not a copy. (Tricky!) • If you modify the scalar variable in foreach, the aliased element in the list is also changed: $ cat double #!/usr/local/bin/perl5 -w @a = (1,2,3,4); foreach $b (@a){ $b *= 2; } print "@a\n"; $ double 2 4 6 8 $

  18. Backward “ if ” (1) • A simple way to write “if this, then that” is: chomp($user = `whoami`); print("Hi Bill!\n") if($user eq "gates"); is the same as: chomp($user = `whoami`); if($user eq "gates"){ print "Hi Bill!\n"; } • Backward if avoids having to write the curly braces { }. • There can only be one statement inside the block.

  19. Backward “ if ” (2) • Backward if is a natural and tidy way to exit from a loop: $ cat backif #!/usr/local/bin/perl5 -w while(1){ print "Wakeup [yes/no]? "; chomp($resp = <STDIN>); last if $resp eq "yes"; }; $ backif Wakeup [yes/no]? no Wakeup [yes/no]? y Wakeup [yes/no]? yes $

  20. && “ if ” (1) • Another simple way to write “if this, then that” is: chomp($user = `whoami`); $user eq "gates" && print("Hi Bill!\n"); is the same as: chomp($user = `whoami`); if($user eq "gates"){ print("Hi Bill!\n"); }

  21. && “ if ” (2) this && that; • Why does this work? • Isn’t && the logical-and operator? • Consider what happens when this and that take on values of true and false: • If this is true, then the value of the entire expression is still not known, because it depends on the value of that. So that has to be evaluated. • If this is false, there is no need to look at that, because the value of the whole expression must be false. Since there is no need to evaluate that, Perl skips it.

  22. && “ if ” (3) • &&if is also a tidy way to exit from a loop: $ cat backif1 #!/usr/local/bin/perl5 -w while(1){ print "Wakeup [yes/no]? "; chomp($resp = <STDIN>); $resp eq "yes" && last; }; $ backif1 Wakeup [yes/no]? no Wakeup [yes/no]? y Wakeup [yes/no]? yes $

More Related