Templates - PowerPoint PPT Presentation

1 / 17
About This Presentation
Title:

Templates

Description:

Establishes a text substitution rule that will replace any ... A Useful Example (abridged) template typename T class vector { public: void push_back(T) ... – PowerPoint PPT presentation

Number of Views:33
Avg rating:3.0/5.0
Slides: 18
Provided by: usersEc3
Category:

less

Transcript and Presenter's Notes

Title: Templates


1
Templates
  • An introduction

2
Whats a macro?
  • A macro is a text-substitution rule.
  • Macros are very common for assembly language, and
    are also used frequently in C programs
  • For example (this is a C macro)
  • define AND
  • Establishes a text substitution rule that will
    replace any occurrence of the text AND with the
    text .
  • The macro processor (the C preprocessor) does
    not check to make sure this substitution makes
    sense, but it does know enough not to replace
    text that is in the middle of a word, so CANDY
    will not be changed into CY
  • int foo(int x)
  • if (x gt 0 AND x lt 10) cout ltlt x is between 1
    and 9

3
Macros can have parameters
  • Macro arguments make macros much more useful, for
    example
  • define increment(x) ((x))
  • define max(x, y) (((x) lt (y) ? (y) (x))
  • int main(void)
  • int a 10
  • int b 10
  • increment(a)
  • cout ltlt max(a, b)
  • Using macro parameters mean that macros can be
    almost like functions.

4
Macros are NOT Functions!
  • So, whats with all the silly parentheses, you
    ask?
  • Macros are text substitution rules, not
    functions, and sometimes the new text will
    interact with existing text in strange ways
  • Parentheses are used to prevent that.
  • define add(x, y) x y
  • int main(void)
  • cout ltlt add(5, 10) 2 // prints 25!
  • int x 3

5
Macros are NOT functions II
  • Since macros are text substitution rules, the
    macro argument can end up being evaluated more
    than once (even with all the parentheses in the
    world), e.g.
  • define increment(x) ((x))
  • define max(x, y) (((x) lt (y) ? (y) (x))
  • int main(void)
  • int a 0
  • cout ltlt max(a, increment(a)) // prints 2
  • cout ltlt a // prints 2

6
Macros are not functions III
  • Whats with the annoying ? in the max macro?
  • The text for a macro must be a single line (it
    doesnt always have to be a single statement).
    Still this causes trouble.
  • define max(x,y) if (x lt y) return y else
    return x
  • int foo(int a, int b)
  • int x max(a, b) // whoops!
  • return x / 2

7
I do not care for macros
  • When your only tool is a hammer, you become very
    proficient with nails
  • A lot of C programmers have very sophisticated
    macro libraries, and use them extensively.
  • But sometimes, what you really need is some glue.
  • Fortunately, C templates make macros pretty
    much useless

8
Simple Template Functions
  • template lttypename Tgt
  • T max(T x, T y)
  • if (x gt y) return x
  • else return y
  • int main(void)
  • int x 0
  • cout ltlt max(x, x) // prints 1
  • cout ltlt x // prints 1
  • string s hello
  • string t world
  • cout ltlt max(s, t) // prints world

9
Whats all this?
  • Templates have ugly syntax. Get used to it, and
    on an exam, be able to get in the ballpark of
    the correct syntax.
  • Conceptually, templates are a lot like macros,
    just without the unpleasant side effects.
  • When you see a template, or use a template, think
    text substitution and youll be close

10
Template Instantiation
  • A template definition is a recipe that the
    compiler can use to generate a function (or a
    class, more on that later)
  • The compiler will not use this recipe
    unless/until you instantiate the template.
  • At that point, the compiler goes and performs the
    text substitution you asked for, and then
    compiles the newly generated function as if youd
    written that function yourself.
  • What happens if I instantiate the same template
    multiple different ways?
  • Well, with function overloading, we just get two
    or more functions with the same name, but with
    different arguments!

11
Example (template definition)
  • template lttypename T, typename Ugt
  • T max(T x, T y)
  • if (x lt y) return y
  • else return x
  • T is the template parameter. Since the T is
    specified as a typename (i.e., the name of some
    type), then T can be replaced by any type
    (e.g., int or string). T can NOT be replaced
    by any arbitrary text, just by a type.
  • We have defined this template, which means the
    compiler now knows the recipe. But there is no
    machine code for the max function yet. The
    compiler wont actually compile the max function
    until we instantiate it.
  • The compiler does do some preliminary syntax
    checking, so you can get compiler errors in your
    template definitions even if you dont
    instantiate them.

12
Example (instantiations)
  • int main(void)
  • int x 3
  • x max(x, 5) // instantiation 1
  • double y max(1.0, 5.0) // instantitation
    2
  • y max(y, y 1) // not a new instantiation
  • y max(x, y) // uh oh! Ambiguous
  • y maxltdoublegt(x, y) // OK, the choice for
    T is explicitly double
  • For the first instantiation, the compiler can
    easily guess that T should be int
  • For the second instantiation, it is also obvious
    that T should be double (floating point
    constants are double)
  • The compiler instantiates a different version of
    the template for each distinct binding of T that
    you use (i.e., one time for int one time for
    double), not each time you call the function.
  • Since both arguments to max are supposed to be
    the same type (T), the compiler cant figure out
    what to do with the ambiguous line, should T be
    int (convert y) or should T be double (convert
    x).
  • We can remove the ambiguity in a few ways, the
    most certain is to simply tell the compiler what
    argument you want for the type paremeter T.

13
Template Classes
  • C also provides template classes.
  • Virtually any data structure (AKA collection,
    AKA container) will be implemented in C as a
    template
  • The type of data stored in the structure is
    really not at all relevant to the data structure
    itself.
  • Template classes get defined and instantiated
    in analogous ways to template functions with the
    following caveats
  • The compiler will never guess at the template
    argument for a template class, you must always
    explicitly tell the compiler what T is.
  • Classes cannot be overloaded, but the compiler
    will permit you to instantiate the same template
    class in multiple ways.
  • Each distinct instantiation results in a
    completely distinct class! (with its own copy of
    the static data members, for example).
  • The member functions in a template class are
    template functions (oh, how confusing!)

14
An example
  • template lttypename Tgt
  • class Foo
  • T x
  • static int count
  • public
  • Foo()
  • x 0
  • count 1
  • T getX(void) return x
  • int howMany(void) return count
  • template lttypename Tgt
  • int FooltTgtcount 0
  • int main(void)
  • Fooltintgt a
  • cout ltlt a.getX() ltlt endl // prints 0
  • Fooltintgt b
  • cout ltlt b.count() ltlt endl // prints 2

15
A Useful Example (abridged)
  • template lttypename Tgt
  • class vector
  • public
  • void push_back(T)
  • void pop_back(void)
  • T operator(int k)
  • explicit vector(int initial_capacity8)
  • private
  • T data
  • int length
  • int capacity
  • void expand(void) // increase capacity

16
Member functions are template functions, ugh.
  • template lttypename Tgt
  • vectorltTgtvector(int init_cap)
  • capacity init_cap
  • data new Tcapacity
  • length 0
  • template lttypename Tgt
  • void vectorltTgtpush_back(T x)
  • if (capacity length) expand()
  • datalength x
  • length 1
  • template lttypename Tgt
  • void vectorltTgtexpand(void)
  • capacity 2
  • T new_data new Tcapacity
  • for (int k 0 k lt length k 1)
    new_datak datak

17
Templates and .h files
  • C programs (just like C) are intended to be
    separately compiled.
  • Each module can be compiled independently and
    then linked together at the end to form the
    executable program.
  • This is nice for large development teams.
  • Type definitions and function declarations that
    are public (i.e., used by more than one module
    in the system) are usually placed into a .h file
  • Any module that needs to know about these
    functions or types simply includes the .h file.
  • When that module is compiled, the compiler checks
    the syntax by which you are calling those
    functions, but the compiler doesnt actually
    generate machine code for those functions i.e.,
    the compiler uses the .h file just to make sure
    the modules will interoperate.
  • BUT templates require that the compiler
    instantiate them (or else theres no machine code
    to interoperate with). And the compiler wont
    know which templates to instantiate (or how to
    instantiate them) until it looks at all the other
    modules in the project.
  • In practice this means that the entire template
    (not just declarations) must be placed into the
    .h file.
  • If youre writing a template class, you might
    consider just accepting this, and expanding all
    your member functions in place (inside the class
    definition).
Write a Comment
User Comments (0)
About PowerShow.com