• Length:
    4 Weeks
  • Effort:
    5–10 hours per week
  • Price:

    FREE
    Add a Verified Certificate for $49 USD

  • Institution
  • Subject:
  • Level:
    Introductory
  • Language:
    English
  • Video Transcript:
    English

Prerequisites

Computing: Art, Magic, Science” (CAMS 1), or equivalent familiarity with topics covered there

About this course

Skip About this course

Computing is a science. It’s an art, at least for those who practice it well, and it still retains much of its magic.

Part 1 of this course introduced the fundamental concepts, preparing you for the more advanced topics covered in this course!

Throughout this course, you will learn programming concepts and techniques, and practice them immediately through advanced browser-based tools that let you write programs, compile, run and test them against predefined test sets. You will see your results right away in your browser!

In this Part 2, we will discuss:

  • A major programming technique, inheritance, including Multiple inheritance: combining complementary abstractions
  • Selective exports for solid modular design of large systems
  • Functional programming with agents: going one level of abstraction higher or more
  • Concurrency: how to build applications that, so to speak, walk and chew gum at the same time
  • Design patterns: how you can benefit from the best architectural practices of the industry, ironed out over many decades
  • What makes a loop do its job right, with the notion of loop invariant
  • Important practical examples: how to write an interactive application with undo-redo, and the example of topological sort
  • Software engineering-- the construction not just of individual programs but also of complex, ambitious software systems

Join us in this computing and programming course to better understand the power and beauty of modern computer programming.

What you'll learn

Skip What you'll learn
  • Multiple inheritance
  • Selective exports
  • Functional programming with agents
  • Concurrency
  • Design patterns
  • Loop invariants
  • Examples: undo-redo, topological sort
  • Introduction to software engineering

Meet your instructors

Bertrand Meyer
Professor
Politecnico di Milano and Innopolis University

Pursue a Verified Certificate to highlight the knowledge and skills you gain $49.00

View a PDF of a sample edX certificate
  • Official and Verified

    Receive an instructor-signed certificate with the institution's logo to verify your achievement and increase your job prospects

  • Easily Shareable

    Add the certificate to your CV or resume, or post it directly on LinkedIn

  • Proven Motivator

    Give yourself an additional incentive to complete the course

  • Support our Mission

    EdX, a non-profit, relies on verified certificates to help fund free education for everyone globally