lecture'1:' canadian university software introduc.on'to...

9
lecture 1: introduc.on to modeling & UML csc302h winter 2014 CUSEC 2014 january 16 – 18, montreal http://2014.cusec.net canadian university software engineering conference administra.ve assignment #1 out by tuesday form groups today sign up on piazza asap! any problems? everyone familiar with piazza? recap from last .me engineering large software systems is difficult! $bn wasted annually on botched projects it isn’t just the big ones that go awry (see boyd’s toast), but they tend to with a greater probability for our purposes, “large” means anything non-trivial that benefits from proper planning and tools, and is likely to be used by someone other than the developer

Upload: others

Post on 18-Jul-2020

5 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM

lecture'1:'introduc.on'to'modeling'&'UML'

csc302h

winter 2014

CUSEC'2014'

january 16 – 18, montreal http://2014.cusec.net

canadian university software engineering conference

administra.ve'

•  assignment #1 out by tuesday •  form groups today •  sign up on piazza asap!

–  any$problems?$

–  everyone$familiar$with$piazza?$

recap'from'last'.me'

•  engineering large software systems is difficult! –  $bn$wasted$annually$on$botched$projects$–  it$isn’t$just$the$big$ones$that$go$awry$$$$$$$$$$$$$$(see$boyd’s$toast),$but$they$tend$to$with$a$

greater$probability$

•  for our purposes, “large” means anything non-trivial that benefits from proper planning and tools, and is likely to be used by someone other than the developer

Page 2: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM

recap'from'last'.me'(2)'

•  work will be done in teams of 6-7

–  ini?al$groups$will$be$formed$today$in$the$

tutorial$hour.$

•  we will be working on a large open source project –  project(s)$selec?on$will$be$finalized$on$tuesday$when$a1$goes$out.$

modeling'

•  one thing that we as software developers/engineers can do to better understand software is by using models

•  many choices when building models – mul?ple$modeling$“languages”$

–  graphical/Textual$–  diagrams$–$ER$diagrams$for$data,$class$and$

object$diagrams$in$OOP.$

–  adMhoc$$•  for this course we’ll use UML (more or less)

modeling'(2)'

•  uml as defined by wikipedia:

•  caveat: how often do I use (strict) uml?

•  but you gotta love software models…I do

“UML is a standardized general-purpose modeling language in the field of object-oriented software engineering. The UML includes a set of graphic notation techniques to create visual models of object-oriented software-intensive systems.”

“…in his eighteen years as a professional programmer, Wilson had only ever worked with one programmer who actually used it voluntarily .” – Two Solitudes Illustrated, Greg Wilson & Jorge Aranda, 2012

Page 3: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM
Page 4: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM
Page 5: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM
Page 6: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM
Page 7: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM
Page 8: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM

sta.c'vs.'dynamic'modeling'

•  static captures fixed code-level relationships –  class$(and$package)$diagrams$

–  object$diagrams$

–  component$diagrams$

–  deployment$diagrams$

•  behavioral diagrams capture dynamic execution –  use$case$diagrams$

–  sequence$and$interac?on$diagrams$

–  collabora?on$diagrams$

–  statechart$diagrams$

–  ac?vity$diagrams$

Page 9: lecture'1:' canadian university software introduc.on'to ...matt/csc302/lectures/01_modeling.pdf · 1_modeling.ppt Author: Matt Medland Created Date: 1/9/2014 4:26:10 AM

summary'

•  summary on modeling –  important$to$use$modeling$during$design$

– modeling$can$be$helpful$to$discover$design$and$

architecture$(a1)$

–  as$with$most$things,$it$can$be$taken$too$far$

–  the$model$should$provide$an$easier$to$consume$

abstrac?on$

–  strict$uml$is$good$when$publishing$designs$for$

external$consump?on$even$if$you$don’t$use$it$

yourself$

short'break,'then…'

group'selec.on!'