Subroutines.

Slides:



Advertisements
Similar presentations
Procedures and Control Flow CS351 – Programming Paradigms.
Advertisements

CS 330 Programming Languages 10 / 14 / 2008 Instructor: Michael Eckmann.
CS 330 Programming Languages 10 / 11 / 2007 Instructor: Michael Eckmann.
Lesson 6 Functions Also called Methods CS 1 Lesson 6 -- John Cole1.
Subroutines. aka: user-defined functions, methods, procdures, sub-procedures, etc etc etc We’ll just say Subroutines. –“Functions” generally means built-in.
Prof. Alfred J Bird, Ph.D., NBCT Office – McCormack 3rd floor 607.
Control Structures. Important Semantic Difference In all of these loops we are going to discuss, the braces are ALWAYS REQUIRED. Even if your loop/block.
Defining and Converting Data Copyright Kip Irvine, 2003 Last Update: 11/4/2003.
Chapter 10: BASH Shell Scripting Fun with fi. In this chapter … Control structures File descriptors Variables.
Data TypestMyn1 Data Types The type of a variable is not set by the programmer; rather, it is decided at runtime by PHP depending on the context in which.
Introduction to Perl “Practical Extraction and Report Language” “Pathologically Eclectic Rubbish Lister”
1 Announcements Note from admins: Edit.cshrc.solaris instead of.tcshrc Note from admins: Do not use delta.ece.
Perl Chapter 6 Functions. Subprograms In Perl, all subprograms are functions – returns 0 or 1 value – although may have “side-effects” optional function.
Topic 4:Subroutines CSE2395/CSE3395 Perl Programming Learning Perl 3rd edition chapter 4, pages 56-72, Programming Perl 3rd edition pages 80-83,
Scripting Languages Diana Trandab ă ț Master in Computational Linguistics - 1 st year
A Few More Functions. One more quoting operator qw// Takes a space separated sequence of words, and returns a list of single-quoted words. –no interpolation.
Chapter Functions 6. Modular Programming 6.1 Modular Programming Modular programming: breaking a program up into smaller, manageable functions or modules.
Introduction to Perl. What is Perl Perl is an interpreted language. This means you run it through an interpreter, not a compiler. Similar to shell script.
Creating FunctionstMyn1 Creating Functions Function can be divided into two groups: –Internal (built in) functions –User-defined functions.
Operators. Perl has MANY operators. –Covered in Chapter 3 of Camel –perldoc perlop Many operators have numeric and string version –remember Perl will.
1 This week Basics of functions Stack frames Stack vs. Heap (brief intro) Calling conventions Storage classes vs. scope Library functions Overloading.
CS314 – Section 5 Recitation 9
CompSci 230 S Programming Techniques
Overview 4 major memory segments Key differences from Java stack
CSE 374 Programming Concepts & Tools
Introduction to Computer Science / Procedural – 67130
Variables, Environments and Closures
Principles of programming languages 4: Parameter passing, Scope rules
Why exception handling in C++?
Chapter 6: Functions Copyright © 2010 Pearson Education, Inc. Publishing as Pearson Addison-Wesley.
Command Line Arguments
Chapter 9 :: Subroutines and Control Abstraction
Object Oriented Programming COP3330 / CGS5409
Overview 4 major memory segments Key differences from Java stack
User Defined Functions
Chap. 8 :: Subroutines and Control Abstraction
Subroutines Web Programming.
Chap. 8 :: Subroutines and Control Abstraction
Functions A function is a “pre-packaged” block of code written to perform a well-defined task Why? Code sharing and reusability Reduces errors Write and.
6 Chapter Functions.
Context.
CISC101 Reminders Assn 3 due tomorrow, 7pm.
Perl Functions.
Lesson 2. Control structures File IO - reading and writing Subroutines
Chapter 6 - Subroutines and Functions
Dynamic Scoping Lazy Evaluation
Object Oriented Programming in java
Variables Title slide variables.
Classes and Objects.
10/4: Lecture Topics Overflow and underflow Logical operations
6.001 SICP Further Variations on a Scheme
Basics (Cont...).
Chapter 6 – Methods Topics are:
Lecture 5: Functions and Parameters
6.001 SICP Variations on a Scheme
COP 3330 Object-oriented Programming in C++
Methods.
Function.
Based on slides created by Bjarne Stroustrup & Tony Gaddis
Java Programming Language
COMPILERS Semantic Analysis
CSE 341 Lecture 11 b closures; scoping rules
CISC101 Reminders Assignment 3 due today.
Function.
INTRODUCTION to PERL PART 1.
Standard Version of Starting Out with C++, 4th Edition
ITM 352 Functions.
四時讀書樂 (春) ~ 翁森 山光照檻水繞廊,舞雩歸詠春風香。 好鳥枝頭亦朋友,落花水面皆文章。 蹉跎莫遣韶光老,人生唯有讀書好。
Storage Classes.
Presentation transcript:

Subroutines

Subroutines aka: user-defined functions, methods, procdures, sub-procedures, etc etc etc We’ll just say Subroutines. "Functions" generally means built-in functions perldoc perlsub

The Basics sub myfunc { print "Hey, I’m in a function!\n"; } #… myfunc(); Because the subroutine is already declared, () are optional (ie, you can just say myfunc; ) If you call the function before declaring it, the () are required You can declare a subroutine without defining it (yet): sub myfunc; Make sure you define it eventually…. actual name of the subroutine is &myfunc ampersand not necessary to call it in fact, has (usually undesirable) side-effects

Parameters my $foobar = 82; myfunc('hello', 'world', $foobar); (aka Arguments, inputs, etc) You can call any subroutine with any number of parameters. The parameters get passed in via local @_ variable. my $foobar = 82; myfunc('hello', 'world', $foobar); sub myfunc{ print join(' ', @_), "\n"; } @_ is a normal array in every way. In this subroutine, $_[0] = 'hello', $_[1] = 'world', and $_[2] = 82 prints 'hello world 82 '

Standard Procedure There are two "normal" ways to obtain individual parameters: sub display { my ($name, $addr) = @_; # . . . } shift() in a subroutine acts on @_ with no args Outside of a subroutine, acts on @ARGV sub display { my $name = shift; my $addr = shift; # . . . } Beware that the second method destroys @_ in the process.

Pass by value vs Pass by reference *All* parameters are passed by reference. A direct change to an element of @_ will affect the variable passed in. To pass by value instead, create a copy: my ($foo, $bar) = ('old', 'old'); change($foo, $bar); sub change { my ($val1, $val2) = @_; $_[0] = 'new'; #changes $foo $val2 = 'new'; #does not change $bar } $foo  'new', $bar  'old' If you use the shift() method, you lose the ability to change the parameters!

& side effect #1 If you use & to call a subroutine, and don't pass any arguments, the current value of @_ will be passed automatically. &myfunc; myfunc’s @_ is alias to current @_ same as saying myfunc(@_); but faster internally In general, don't call the subroutine with &. if your subroutine checks for parameters, and you don't explicitly pass parameters, @_ will not be empty as you expect.

Squashing array parameters If arrays or hashes are passed into a subroutine, they get ‘squashed’ into one flat array: @_ my @a = (1, 2, 3); my @b = (8, 9, 10); myfunc (@a, @b); inside myfunc, @_  (1, 2, 3, 8, 9, 10); Same as my @c = (@a, @b); myfunc(@c); Maybe this is what you want. if not, you need to use references…

References in Parameters To pass arrays (or hashes), and not squash them: my @a = (1, 2, 3); my @b = (8, 9, 10); myfunc (\@a, \@b); In subroutine, @_ contains two scalar values. Each one is a reference to an array. sub myfunc{ my ($ref1, $ref2) = @_; my @x = @{$ref1}; my @y = @{$ref2}; #… }

Pass by Reference, take 2 To not change a scalar, copy the value from @_ foo($val); sub foo { $_[0] = 'new'; } Changes $val sub foo { my $copy = $_[0]; $copy = 'new'; } Does not change $val To not change an array, you must copy the array that is referenced! bar(\@vals); sub bar { push @{$_[0]}, 'new'; } Changes @vals sub bar { my $copy = $_[0]; push @{$copy}, 'new'; } CHANGES @vals!!! $_[0] and $copy are two different references, but they both refer to the same array sub bar { my @copy = @{$_[0]}; push @copy, 'new'; } Does not change @vals @copy is a different array than @{$_[0]}

Return values All Perl blocks return last expression evaluated. sub add2 { $_[0] + $_[1]; } $total = add2(4, 5); $total  9 return keyword used for explicitness, or to leave the subroutine before its lexical end sub myfunc{ if (!@_){ warn "myfunc called with no args!"; return -1; } # . . . }

Return issues Can return values in list or scalar context. sub toupper{ my @params = @_; tr/a-z/A-Z/ for @params; return @params; } my @uppers = toupper $word1, $word2; my $upper = toupper $word1, $word2; $upper gets size of @params Why not use tr/a-z/A-Z/ for @_; ?

Scalar vs List Returns wantarray function Built-in function. If subroutine called in list context, wantarray returns true If subroutine called in scalar context, wantarray returns false If subroutine called in void context, wantarray returns undef. Perhaps we want to return an entire array in list context, but the first element of the array in scalar context: sub fctn{ warn "fctn() called in void context" unless defined wantarray; #. . . return wantarray ? @params : $params[0]; }

Subroutine References To take a reference to a subroutine, use the & and prepend a \, like you would for any other variable: my $fooref = \&foo; You can declare a reference to an anonymous subroutine Store the ‘return value’ of sub in a scalar variable $subref = sub { print "Hello\n"; }; to call, de-reference the stored value: &$subref; $subref->(); #preferred works with parameters too.. &$subref($param1, $param2); $subref->($param1, $param2); Sub refs can be stored in arrays or hashes to create "dispatch tables" my @dispatch = (\&foo, $subref, \&baz); my $var = <STDIN>; $dipatch[$var]->();

Scoping Recall that there are two distinct scopes of variables: Package variables and Lexical variables. Package variables available anywhere, without being declared Perl has two ways of creating 'local' variables local and my what you may think of as local (from C/C++) is actually achieved via my. local is mostly a holdover from Perl 4, which did not have lexical variables.

Where’s the scope subroutines declared within a lexical’s scope have access to that lexical this is one way of implementing static variables in Perl prior to 5.10, the only way { my $num = 20; sub add_to_num { $num++ } sub print_num { print "num = $num";} } add_to_num; #increments $num print_num; #prints current val of $num print $num; #ERROR!

local in fctn(), $main::x has a temporary value created by local local does not create new variable instead, assigns temporary value to existing package variable has dynamic scope functions called from within scope of local variable get the temporary value our ($x, $y) = (10, 20); sub fctn { print "x = $x, y = $y\n"; } { local $x = 1; my $y = 2; fctn(); } in fctn(), $main::x has a temporary value created by local The lexical $y is not accessible to fctn prints "x = 1, y = 20"

state (5.10 exclusive) A lexical variable that remembers the last value it had before it went out of scope is a "static" variable use feature ':5.10'; sub count_it { state $x = 0; say "count_it called $x times before"; $x++; } count_it(); count_it(); count_it(); say "I've called count_it $x times"; # ERROR!! The initialization is done only the first time this sub is called. After that, variable is initialized with last value it had before it went out of scope the last time.

What to know about scope my is lexically scoped Look at the actual code. Whatever block encloses my is the scope of the variable our is also lexically scoped allows you to use a global package variable without fully qualifying local is dynamically scoped The scope is the enclosing block, plus any subroutines called from within that block state is lexically scoped But it remembers its previous value (only available in 5.10.0 or higher) Almost always want my instead of local notable exception: cannot create lexical variables such as $_, $/, $", $,, etc. Only ‘normal’, alpha-numeric variables Exception: can lexicalize $_ in 5.10.0 and higher. for built-in variables, localize them. See also: "Coping With Scoping" http://perl.plover.com/FAQs/Namespaces.html

Prototypes Perl’s way of letting you limit how you’ll allow your sub to be called. when declaring the sub, give it the ‘type’ of variables it takes sub f1($$) {…} f1 must take two scalar values sub f2($@) {…} f2 takes a scalar value, followed by a list of values recall a list can contain 0, 1, or any number of values sub f3(\@$) {…} f3 takes an actual array, followed by a scalar value sub f4() {…} f4 takes zero arguments of any kind "Too many arguments for main::f4" Get rid of those parentheses!! sub f5(_) {...} f5 takes a single scalar, but defaults to $_ if not given 5.10.0 and higher only

Don’t use prototypes Prototypes are almost universally considered a mistake in the language. They should NEVER be used. They create a false sense of security, letting you think you don’t need to check your args manually. They frequently do NOT work as expected. sub fctn($@) { ... } fctn(@foo); NO ERROR! Instead, converts @foo to scalar context, and lets the second argument be an empty list. sub avg($$) { ... } my @args = ($val1, $val2); avg(@args); ERROR! Won’t let you pass the array containing two values

Even more pointless... The second side-effect of calling a subroutine with the & is to disable prototype checking entirely sub foo($) { ... } foo(@bar, %baz); #Error &foo(@bar, %baz); #No error

Warning your users If something goes wrong in a subroutine, it's often helpful to know where the subroutine was called. sub fctn { warn "fctn called in void context" unless defined wantarray; } This will only tell the user an error occurred within the subroutine, line number will be the line of the warn() use Carp; sub fctn { carp "fctn called in void context" unless defined wantarray; } Line number reported will be line on which fctn() was called. croak : carp :: die : warn

Who called me? caller EXPR - return information about what called this subroutine No args, scalar context: package from which sub was called No args, list context: (package, filename, line number) from which this sub was called Integer passed, list context: integer is how many calls to back up the call stack (0 for current sub) returns (package, filename, line number, sub name, hasargs, wantarray, evaltext...)