Building Routines. Quality Routines. Quality Routines. Quality Routines. Quality Routines. Routine. What makes a quality routine
|
|
- Bethany George
- 5 years ago
- Views:
Transcription
1 Building Routines Routine individual function or procedure invocable for a single purpose What makes a quality routine easier to see a low quality routine low quality routine coming up Procedure HandleStuff( Var InputRec: CORP_DATA, CrntQtr: integer, EmpRec: EMP_DATA, Var EstimRevenue: Real, ScreenX: integer, ScreenY: integer, Var NewColour: COLOUR_TYPE, Var PrevColour: COLOUR_TYPE, Var Status: STATUS_TYPE, ExpenseType: integer) begin for i:=1 to 100 do begin InputRec.revenue[i] :=0; InputRec.expense[i] :=CorpExpense[CrntQtr, 1]; end; UpdateCorpDatabase(EmpRec); EstimRevenue :=YTDRevenue*4.0/real(CrntQtr); NewColour :=PrevColour; Status :=Success; if ExpenseType = 1 then begin Profit := Revenue[i] - Expense.Type1[i]; end else if ExpenseeType = 2 then begin Profit := Revenue[i] - Expense.Type2[i]; end end; March 06 1 March 06 2 what s wrong with the previous routine bad name - HandleStuff() not documented bad layout modifies global variables (CorpExpense, Profit) doesn t have a single purpose initialises variables, writes to database, does calculations don t seem to be related uses magic numbers doesn t defend against bad data YTD*4/real(CrntQtr) make programs easier to read and understand helps save space and improve performance reduces repetition of code reasons to create quality code reduce complexity hide information so you don t have to think about it over and over avoid duplicate code why reinvent the wheel March 06 3 March 06 4 limit the effects of changes isolate area likely to change and reduce the effect hiding sequences program gets data from user and gets data from a file neither routine should depend on the other being performed first improving performance optimise in one place instead of several single optimisation benefits in many places making central points of control using one routine for reading from files etc March 06 5 if file data needs to be written to certain form, then only done in one place hiding data structures most of the program doesn t have to worry about structure manipulation provides level of abstraction to reduce complexity hiding pointer operations tend to be hard to read and error prone isolating allows improvement or replacement easily promote code reuse add modules to new projects March 06 6
2 planning for a family of programs basic model of software for everybody customisable parts in separate modules expect to change these for different customers making the code more readable well named routines make code easier to read and understand If (Node <> NULL) while (Node.next <>NULL) do Node = Node.next LeafName = Node.Name else LeafName = default LeafName = GetLeafName ( Node) March 06 7 improving portability using routines isolates nonportable capabilities nonstandard features, hardware dependencies identifies future work isolate complex operations scientific algorithms etc isolate use of non standard functions using nonstandard functions - double edged sword may not be available in other environments, platforms build gateway routines to the nonstandards to make them easier to replace March 06 8 Too simple for a routine? Is a 2 or 3 line routine overkill? Consider the following Points = DeviceUnits * (POINTS_PER_INCH / DeviceUnitsPerInch ()) not a complicated line eventually figure out the it converts measurement in device units to points clearer however to do the following create a function DeviceUnitsToPoints( DeviceUnits Integer ): Integer begin DeviceUnitsToPoints = DeviceUnits * (POINTS_PER_INCH / DeviceUnitsPerInch () ) end and then write the previous line as Points = DeviceUnitsToPoints( DeviceUnits ) more readable and self documenting also, may have to modify the function originally modify lines everywhere function call went may have to account for division by zero or some other error March 06 9 March how long is a routine? Theoretical maximum often described as one or two pages of code listing lines evidence in favour of short routines is thin arguments for longer routines routine size inversely correlated with errors as sized increased, errors per lines of code decreased Basili & Perricone study found that short routines were not correlated with lower cost or fault rate evidence suggested that lopnger routines were cheaper to develop per line of code empirical study of 450 routines found that the smaller (143 lines or less) had 23% more errors per line of code so what? If a routine needs to be 50 or 200 lines to make sense make it so current evidence suggests that routines up to 200 lines are no more error prone and cheaper to develop March March 06 12
3 > 200 lines - be careful line being a non comment, non blank line of source no study done has reported decreased cost or error rates with larger routines upper limit of understandability study of line program routines with fewer than 143 source lines were 2.4 times less expensive to fix March not my code does work, outside now! based on the idea of defensive driving never sure what the other drivers are going to do take responsibility for protecting yourself even when it is the other driver s fault defensive programming if a routine is passed bad data, it won t get hurt recognition that programs will have problems and modifications smart programmer develops accordingly March best form of defensive programming don t install the errors in the first place using iterative design, writing PDL before code, low level design inspections all used to prevent installing defects should be given priority over defensive programming Other Techniques Assertions function or macro that complains loudly if assumption is false March Assertions use them to document assumptions and to flush out unexpected conditions usually takes two arguments boolean expression that describes the assumption message to print if its not example instead of assert ( p!= NULL) if ( p!= NULL) { do something } March Assertions useful during development and maintenance assertion routine #ifdef DEBUG Void _Assert(char *, unsigned); void _Assert(char *strfile, unsigned uline); { fflush(null); fprintf(stderr, \nassertion failed: %s, line %u, strfile, uline); fflush(stderr); abort(); } #define ASSERT(f) if (f) {} else _Assert( FILE, LINE) #else #define ASSERT(f) #endif March Assertions use preprocessor macros for assertions easier to use during development and then take out for release avoid putting executable code in assertions asserting that the FileOpen worked call the FileOpen and assign the return value to a status variable then check the status variable March 06 18
4 Garbage in does not mean garbage out check values of all data input from external sources allowable ranges, strings lengths comment assumptions about input ranges check values of all routine input parameters Float Tan( float OppositeLength, float AdjacentLength) { Assert( AdjacentLength!=0, Adjacent Length is 0 return (OppositeLength/AdjacentLenght) } March decide how to handle bad parameters may want to return error code return neutral value substitute with next piece of valid data and continue return same answer as previous use closest legal value or default value lot of options architectural decision be consistent throughout the code you are writing March Exception Handling used to draw attention to unexpected cases should be handled in a way to make them obvious during development and recoverable after installation example is the default part of the case statement should give useful messages and be graceful Debugging Aids #ifdef DEBUG can write debug routines called to check various parts of the program and the data Firewalling to contain damage information hiding less you know about the internal workings of a routine less assumptions you make about it less chance that you are wrong loose coupling also helps when routines are not dependent on each other, an error in one is less likely to affect the other design interface boundaries anything inside the interface is safe and yours must decide where to put the boundaries March March Checking function return values always check the return value even if you don t have to guards against unexpected errors true for system functions as well How much defensive programming to leave in release code? During development, want errors to be as visible as possible, in release - want them unobstrusive March Leave code that checks for important errors what can afford to have undetected errors and what is too critical not to Remove code that results in hard crashes users don t appreciate loss of work no matter how helpful in finding a fault if your debugging code causes a system failure then remove it Leave in code that helps the system crash gracefully March 06 24
5 Make sure messages are user friendly too much defensive programming causes problems may cause the program to be fat and slow addition code may add additional complexity defensive code not immune to errors March make sure that the formal match the actual formal - in definition actual - used in actual routine calls common mistake to put the wrong types in calls put parameters in input-modify-output order only a suggestion be consistent by value or by reference if several routines use similar parameters, list all in the same order March use all the parameters otherwise remove what s not used two exceptions functions pointers in C or procedure variables in Pascal compiling parts of code conditionally certain parts may use certain parameters put status or error variables last convention to put these last in the list don t use routine parameters as working variables use local variables instead document interface assumptions about parameters if you assume that data passed to your function has certain characteristics, document this write the assumptions at the time of coding, not later input only, modified, output only units of numeric parameters March March meaning of status codes and error values range of expected values don t use specific values limit the number of parameters to about 7 depends on the complexity of the parameters and the data structures they are handling if you pass the same data to many different routines group the routines and use the data as module data consider input, output, modify naming conventions pass only the parts of structured variables that the routine needs may be better in some cases than passing the entire structure with 90% unused in the routine March March 06 30
6 Functions & Procedures The Purist Argument function should return only one value take only input parameters and return its only value through the function itself named for the return value Sin(), CustomerID() procedure take input, modify, output parameters common practice function operates as a procedure and returns a status value March example Functions & Procedures if (FormatString(input, formatting, output) == SUCCESS then... other option create a procedure and add a status variable as a parameter FormatOutput( input, formatting, output, STATUS) if (Status == SUCCESS) then... unique risk of functions return its value improperly March 06 32
CS 240 Final Exam Review
CS 240 Final Exam Review Linux I/O redirection Pipelines Standard commands C++ Pointers How to declare How to use Pointer arithmetic new, delete Memory leaks C++ Parameter Passing modes value pointer reference
More informationSoftware Implementation (Writing Quality Code)
Software Implementation (Writing Quality Code) void HandleStuff( CORP_DATA & inputrec, int crntqtr, EMP_DATA emprec, float & estimrevenue, float ytdrevenue, int screenx, int screeny, COLOR_TYPE & newcolor,
More informationCompiler Design Spring 2017
Compiler Design Spring 2017 5.0 Software design Dr. Zoltán Majó Compiler Group Java HotSpot Virtual Machine Oracle Corporation 1 Code quality What is quality? All exams have high quality. Student: Exam
More informationIntro. Scheme Basics. scm> 5 5. scm>
Intro Let s take some time to talk about LISP. It stands for LISt Processing a way of coding using only lists! It sounds pretty radical, and it is. There are lots of cool things to know about LISP; if
More informationCS 370 High-Quality Routines D R. M I C H A E L J. R E A L E F A L L
CS 370 High-Quality Routines D R. M I C H A E L J. R E A L E F A L L 2 0 1 5 Introduction Routine An individual method or procedure invocable for a single purpose Examples: function in C++, method in Java,
More informationCode Complete. Steve McConnell
Code Complete Steve McConnell 8. Defensive Programming DEFENSIVE PROGRAMMING DOESN T MEAN being defensive about your programming It does so work! The idea is based on defensive driving. In defensive driving,
More informationReliable programming
Reliable programming How to write programs that work Think about reliability during design and implementation Test systematically When things break, fix them correctly Make sure everything stays fixed
More informationSoftware Construction #1: Creating High-Quality Code
Software Construction #1: Creating High-Quality Code Minsoo Ryu Hanyang University Software construction Software construction is mostly coding and debugging But also involves detailed design, construction
More informationQUIZ. What are 3 differences between C and C++ const variables?
QUIZ What are 3 differences between C and C++ const variables? Solution QUIZ Source: http://stackoverflow.com/questions/17349387/scope-of-macros-in-c Solution The C/C++ preprocessor substitutes mechanically,
More informationQUIZ. What is wrong with this code that uses default arguments?
QUIZ What is wrong with this code that uses default arguments? Solution The value of the default argument should be placed in either declaration or definition, not both! QUIZ What is wrong with this code
More informationRegression testing. Whenever you find a bug. Why is this a good idea?
Regression testing Whenever you find a bug Reproduce it (before you fix it!) Store input that elicited that bug Store correct output Put into test suite Then, fix it and verify the fix Why is this a good
More informationCS 370 The Pseudocode Programming Process D R. M I C H A E L J. R E A L E F A L L
CS 370 The Pseudocode Programming Process D R. M I C H A E L J. R E A L E F A L L 2 0 1 5 Introduction At this point, you are ready to beginning programming at a lower level How do you actually write your
More informationThese are notes for the third lecture; if statements and loops.
These are notes for the third lecture; if statements and loops. 1 Yeah, this is going to be the second slide in a lot of lectures. 2 - Dominant language for desktop application development - Most modern
More informationDifference Between Dates Case Study 2002 M. J. Clancy and M. C. Linn
Difference Between Dates Case Study 2002 M. J. Clancy and M. C. Linn Problem Write and test a Scheme program to compute how many days are spanned by two given days. The program will include a procedure
More informationTopic 6: A Quick Intro To C. Reading. "goto Considered Harmful" History
Topic 6: A Quick Intro To C Reading Assumption: All of you know basic Java. Much of C syntax is the same. Also: Some of you have used C or C++. Goal for this topic: you can write & run a simple C program
More informationSteps for project success. git status. Milestones. Deliverables. Homework 1 submitted Homework 2 will be posted October 26.
git status Steps for project success Homework 1 submitted Homework 2 will be posted October 26 due November 16, 9AM Projects underway project status check-in meetings November 9 System-building project
More informationTesting. UW CSE 160 Winter 2016
Testing UW CSE 160 Winter 2016 1 Testing Programming to analyze data is powerful It s useless (or worse!) if the results are not correct Correctness is far more important than speed 2 Famous examples Ariane
More informationCS 142 Style Guide Grading and Details
CS 142 Style Guide Grading and Details In the English language, there are many different ways to convey a message or idea: some ways are acceptable, whereas others are not. Similarly, there are acceptable
More informationThe compiler is spewing error messages.
Appendix B Debugging There are a few different kinds of errors that can occur in a program, and it is useful to distinguish between them in order to track them down more quickly. Compile-time errors are
More informationCS113: Lecture 7. Topics: The C Preprocessor. I/O, Streams, Files
CS113: Lecture 7 Topics: The C Preprocessor I/O, Streams, Files 1 Remember the name: Pre-processor Most commonly used features: #include, #define. Think of the preprocessor as processing the file so as
More informationCS 520 Theory and Practice of Software Engineering Fall 2018
CS 520 Theory and Practice of Software Engineering Fall 2018 Nediyana Daskalova Monday, 4PM CS 151 Debugging October 30, 2018 Personalized Behavior-Powered Systems for Guiding Self-Experiments Help me
More informationCS 161 Computer Security
Wagner Spring 2014 CS 161 Computer Security 1/27 Reasoning About Code Often functions make certain assumptions about their arguments, and it is the caller s responsibility to make sure those assumptions
More informationLectures 5-6: Introduction to C
Lectures 5-6: Introduction to C Motivation: C is both a high and a low-level language Very useful for systems programming Faster than Java This intro assumes knowledge of Java Focus is on differences Most
More informationThe Software Design Process. CSCE 315 Programming Studio, Fall 2017 Tanzir Ahmed
The Software Design Process CSCE 315 Programming Studio, Fall 2017 Tanzir Ahmed Outline Challenges in Design Design Concepts Heuristics Practices Challenges in Design A problem that can only be defined
More informationDesign and development of embedded systems for the Internet of Things (IoT) Fabio Angeletti Fabrizio Gattuso
Design and development of embedded systems for the Internet of Things (IoT) Fabio Angeletti Fabrizio Gattuso Why C? Test on 21 Android Devices with 32-bits and 64-bits processors and different versions
More informationLectures 5-6: Introduction to C
Lectures 5-6: Introduction to C Motivation: C is both a high and a low-level language Very useful for systems programming Faster than Java This intro assumes knowledge of Java Focus is on differences Most
More informationEXAMINING THE CODE. 1. Examining the Design and Code 2. Formal Review: 3. Coding Standards and Guidelines: 4. Generic Code Review Checklist:
EXAMINING THE CODE CONTENTS I. Static White Box Testing II. 1. Examining the Design and Code 2. Formal Review: 3. Coding Standards and Guidelines: 4. Generic Code Review Checklist: Dynamic White Box Testing
More informationRobust Programming. Style of programming that prevents abnormal termination and unexpected actions
Robust Programming Style of programming that prevents abnormal termination and unexpected actions Code handles bad inputs reasonably Code assumes errors will occur and takes appropriate action Also called
More informationBIL 104E Introduction to Scientific and Engineering Computing. Lecture 4
BIL 104E Introduction to Scientific and Engineering Computing Lecture 4 Introduction Divide and Conquer Construct a program from smaller pieces or components These smaller pieces are called modules Functions
More informationBest Practices in Programming
Best Practices in Programming from B. Kernighan & R. Pike, The Practice of Programming Giovanni Agosta Piattaforme Software per la Rete Modulo 2 Outline 1 2 Macros and Comments 3 Algorithms and Data Structures
More informationTesting is a very big and important topic when it comes to software development. Testing has a number of aspects that need to be considered.
Testing Testing is a very big and important topic when it comes to software development. Testing has a number of aspects that need to be considered. System stability is the system going to crash or not?
More informationSample Exam ISTQB Advanced Test Analyst Answer Rationale. Prepared By
Sample Exam ISTQB Advanced Test Analyst Answer Rationale Prepared By Released March 2016 TTA-1.3.1 (K2) Summarize the generic risk factors that the Technical Test Analyst typically needs to consider #1
More informationQUIZ. Source:
QUIZ Source: http://stackoverflow.com/questions/17349387/scope-of-macros-in-c Ch. 4: Data Abstraction The only way to get massive increases in productivity is to leverage off other people s code. That
More informationTESTING, DEBUGGING, EXCEPTIONS, ASSERTIONS
TESTING, DEBUGGING, EXCEPTIONS, ASSERTIONS (download slides and.py files and follow along!) 6.0001 LECTURE 7 6.0001 LECTURE 7 1 WE AIM FOR HIGH QUALITY AN ANALOGY WITH SOUP You are making soup but bugs
More informationC Review. MaxMSP Developers Workshop Summer 2009 CNMAT
C Review MaxMSP Developers Workshop Summer 2009 CNMAT C Syntax Program control (loops, branches): Function calls Math: +, -, *, /, ++, -- Variables, types, structures, assignment Pointers and memory (***
More informationUnit Testing as Hypothesis Testing
Unit Testing as Hypothesis Testing Jonathan Clark September 19, 2012 5 minutes You should test your code. Why? To find bugs. Even for seasoned programmers, bugs are an inevitable reality. Today, we ll
More informationIntroduction to OpenMP
Introduction to OpenMP p. 1/?? Introduction to OpenMP Synchronisation Nick Maclaren Computing Service nmm1@cam.ac.uk, ext. 34761 June 2011 Introduction to OpenMP p. 2/?? Summary Facilities here are relevant
More informationTopic 6: A Quick Intro To C
Topic 6: A Quick Intro To C Assumption: All of you know Java. Much of C syntax is the same. Also: Many of you have used C or C++. Goal for this topic: you can write & run a simple C program basic functions
More informationCSE 374 Programming Concepts & Tools
CSE 374 Programming Concepts & Tools Hal Perkins Fall 2017 Lecture 8 C: Miscellanea Control, Declarations, Preprocessor, printf/scanf 1 The story so far The low-level execution model of a process (one
More informationProgram development plan
Appendix A Program development plan If you are spending a lot of time debugging, it is probably because you do not have an effective program development plan. A typical, bad program development plan goes
More informationThe C Programming Language Guide for the Robot Course work Module
The C Programming Language Guide for the Robot Course work Module Eric Peasley 2018 v6.4 1 2 Table of Contents Variables...5 Assignments...6 Entering Numbers...6 Operators...7 Arithmetic Operators...7
More informationCSE 504. Expression evaluation. Expression Evaluation, Runtime Environments. One possible semantics: Problem:
Expression evaluation CSE 504 Order of evaluation For the abstract syntax tree + + 5 Expression Evaluation, Runtime Environments + + x 3 2 4 the equivalent expression is (x + 3) + (2 + 4) + 5 1 2 (. Contd
More informationFundamentals. Fundamentals. Fundamentals. We build up instructions from three types of materials
Fundamentals We build up instructions from three types of materials Constants Expressions Fundamentals Constants are just that, they are values that don t change as our macros are executing Fundamentals
More informationEnhance Your Productivity and Software Quality with Techniques from Silicon Valley
Enhance Your Productivity and Software Quality with Techniques from Silicon Valley Benjamin S. Skrainka University College London Institute for Fiscal Studies b.skrainka@ucl.ac.uk July 21, 2010 The Big
More informationVARIABLES. Aim Understanding how computer programs store values, and how they are accessed and used in computer programs.
Lesson 2 VARIABLES Aim Understanding how computer programs store values, and how they are accessed and used in computer programs. WHAT ARE VARIABLES? When you input data (i.e. information) into a computer
More informationJ.1 Pseudo-Variable
J.1 The @TRACE Pseudo-Variable HLA v1.x has a few serious defects in its design. One major issue is debugging support. HLA v1.x emits MASM code that it runs through MASM in order to produce executable
More informationVerification, Testing, and Bugs
Verification, Testing, and Bugs Ariane 5 Rocket First Launch Failure https://www.youtube.com/watch?v=gp_d8r- 2hwk So What Happened? The sequence of events that led to the destruction of the Ariane 5 was
More informationThread Safety. Review. Today o Confinement o Threadsafe datatypes Required reading. Concurrency Wrapper Collections
Thread Safety Today o Confinement o Threadsafe datatypes Required reading Concurrency Wrapper Collections Optional reading The material in this lecture and the next lecture is inspired by an excellent
More informationCS3157: Advanced Programming. Outline
CS3157: Advanced Programming Lecture #8 Feb 27 Shlomo Hershkop shlomo@cs.columbia.edu 1 Outline More c Preprocessor Bitwise operations Character handling Math/random Review for midterm Reading: k&r ch
More informationEE 382 Style Guide. March 2, 2018
EE 382 Style Guide March 2, 2018 This is a short document describing the coding style for this class. All code written in this class is assumed to follow this coding style. 1 Indentation Indentations should
More informationCompiler Construction D7011E
Compiler Construction D7011E Lecture 14: Memory Management Viktor Leijon Slides largely by Johan Nordlander with material generously provided by Mark P. Jones. 1 First: Run-time Systems 2 The Final Component:
More informationGenerating Rectify( ) Test driven development approach to TigerSHARC
Generating Rectify( ) Test driven development approach to TigerSHARC assembly code production Assembly code examples Part 1 of 3 Concepts Concepts of C++ stubs Forcing the test to fail test of test Generating
More informationMeasuring Complexity
Measuring Complexity outline why should we measure the complexity of a software system? what might we want to measure? complexity of the source code within a code module between code modules complexity
More informationCS 241 Honors Memory
CS 241 Honors Memory Ben Kurtovic Atul Sandur Bhuvan Venkatesh Brian Zhou Kevin Hong University of Illinois Urbana Champaign February 20, 2018 CS 241 Course Staff (UIUC) Memory February 20, 2018 1 / 35
More informationShort Notes of CS201
#includes: Short Notes of CS201 The #include directive instructs the preprocessor to read and include a file into a source code file. The file name is typically enclosed with < and > if the file is a system
More informationCSE 143. Programming is... Principles of Programming and Software Engineering. The Software Lifecycle. Software Lifecycle in HW
Principles of Programming and Software Engineering Textbook: hapter 1 ++ Programming Style Guide on the web) Programming is......just the beginning! Building good software is hard Why? And what does "good"
More informationIntermediate Programming, Spring 2017*
600.120 Intermediate Programming, Spring 2017* Misha Kazhdan *Much of the code in these examples is not commented because it would otherwise not fit on the slides. This is bad coding practice in general
More informationPreventing and Finding Bugs in Parallel Programs
Preventing and Finding Bugs in Parallel Programs Charlie Peck Earlham College BW/UPEP Institute @ NCSA May, 2011 1 How Did We Get Here? Debugging serial programs can be hard; debugging parallel programs
More informationHeap Arrays. Steven R. Bagley
Heap Arrays Steven R. Bagley Recap Data is stored in variables Can be accessed by the variable name Or in an array, accessed by name and index a[42] = 35; Variables and arrays have a type int, char, double,
More information1. Describe History of C++? 2. What is Dev. C++? 3. Why Use Dev. C++ instead of C++ DOS IDE?
1. Describe History of C++? The C++ programming language has a history going back to 1979, when Bjarne Stroustrup was doing work for his Ph.D. thesis. One of the languages Stroustrup had the opportunity
More information#include <stdio.h> int main() { printf ("hello class\n"); return 0; }
C #include int main() printf ("hello class\n"); return 0; Working environment Linux, gcc We ll work with c9.io website, which works with ubuntu I recommend to install ubuntu too Also in tirgul
More informationProgramming Style. Quick Look. Features of an Effective Style. Naming Conventions
Programming Style Quick Look An effective programming style helps you write code that is easier to understand, debug, maintain, and port from system to system. This article discusses the general features
More informationCS201 - Introduction to Programming Glossary By
CS201 - Introduction to Programming Glossary By #include : The #include directive instructs the preprocessor to read and include a file into a source code file. The file name is typically enclosed with
More information4. Java Project Design, Input Methods
4-1 4. Java Project Design, Input Methods Review and Preview You should now be fairly comfortable with creating, compiling and running simple Java projects. In this class, we continue learning new Java
More informationSpecial Topics: Programming Languages
Lecture #23 0 V22.0490.001 Special Topics: Programming Languages B. Mishra New York University. Lecture # 23 Lecture #23 1 Slide 1 Java: History Spring 1990 April 1991: Naughton, Gosling and Sheridan (
More informationAnnotation Annotation or block comments Provide high-level description and documentation of section of code More detail than simple comments
Variables, Data Types, and More Introduction In this lesson will introduce and study C annotation and comments C variables Identifiers C data types First thoughts on good coding style Declarations vs.
More informationSelection the If Statement Try Catch and Validation
Selection the If Statement Try Catch and Validation The main statement used in C# for making decisions depending on different conditions is called the If statement. A second useful structure in a similar
More informationTopics in Software Testing
Dependable Software Systems Topics in Software Testing Material drawn from [Beizer, Sommerville] Software Testing Software testing is a critical element of software quality assurance and represents the
More informationFeasibility of Testing to Code. Feasibility of Testing to Code. Feasibility of Testing to Code. Feasibility of Testing to Code (contd)
Feasibility of Testing to Code (contd) Feasibility of Testing to Code (contd) An incorrect code fragment for determining if three integers are equal, together with two test cases Flowchart has over 10
More informationType Checking and Type Equality
Type Checking and Type Equality Type systems are the biggest point of variation across programming languages. Even languages that look similar are often greatly different when it comes to their type systems.
More informationDDMD AND AUTOMATED CONVERSION FROM C++ TO D
1 DDMD AND AUTOMATED CONVERSION FROM C++ TO D Daniel Murphy (aka yebblies ) ABOUT ME Using D since 2009 Compiler contributor since 2011 2 OVERVIEW Why convert the frontend to D What s so hard about it
More informationData Structures and Algorithms for Engineers
04-630 Data Structures and Algorithms for Engineers David Vernon Carnegie Mellon University Africa vernon@cmu.edu www.vernon.eu Data Structures and Algorithms for Engineers 1 Carnegie Mellon University
More informationSoftware Engineering Testing and Debugging Testing
Software Engineering Testing and Debugging Testing Prof. Dr. Peter Thiemann Universitt Freiburg 08.06.2011 Recap Testing detect the presence of bugs by observing failures Debugging find the bug causing
More informationFixed-Point Math and Other Optimizations
Fixed-Point Math and Other Optimizations Embedded Systems 8-1 Fixed Point Math Why and How Floating point is too slow and integers truncate the data Floating point subroutines: slower than native, overhead
More informationC Fundamentals & Formatted Input/Output. adopted from KNK C Programming : A Modern Approach
C Fundamentals & Formatted Input/Output adopted from KNK C Programming : A Modern Approach C Fundamentals 2 Program: Printing a Pun The file name doesn t matter, but the.c extension is often required.
More informationD Programming Language
Group 14 Muazam Ali Anil Ozdemir D Programming Language Introduction and Why D? It doesn t come with a religion this is written somewhere along the overview of D programming language. If you actually take
More informationFunctions and Decomposition
Unit 4 Functions and Decomposition Learning Outcomes Design and implement functions to carry out a particular task. Begin to evaluate when it is necessary to split some work into functions. Locate the
More informationPointer Basics. Lecture 13 COP 3014 Spring March 28, 2018
Pointer Basics Lecture 13 COP 3014 Spring 2018 March 28, 2018 What is a Pointer? A pointer is a variable that stores a memory address. Pointers are used to store the addresses of other variables or memory
More information1007 Imperative Programming Part II
Agenda 1007 Imperative Programming Part II We ve seen the basic ideas of sequence, iteration and selection. Now let s look at what else we need to start writing useful programs. Details now start to be
More informationSoftware Design COSC 4353/6353 D R. R A J S I N G H
Software Design COSC 4353/6353 D R. R A J S I N G H Week 5 Refactoring What is Refactoring? Code Smells Why Refactoring? Techniques IDEs What is Refactoring? Art of improving the design of existing code
More informationUnit Testing as Hypothesis Testing
Unit Testing as Hypothesis Testing Jonathan Clark September 19, 2012 You should test your code. Why? To find bugs. Even for seasoned programmers, bugs are an inevitable reality. Today, we ll take an unconventional
More informationcs3157: another C lecture (mon-21-feb-2005) C pre-processor (3).
cs3157: another C lecture (mon-21-feb-2005) C pre-processor (1). today: C pre-processor command-line arguments more on data types and operators: booleans in C logical and bitwise operators type conversion
More informationWhat's that? Why? Is one "better" than the other? Terminology. Comparison. Loop testing. Some experts (e.g. Pezze & Young) call it structural testing
Week 9: More details of white-box testing What is it? Comparison with black-box testing What we should not validate Automated versus interactive testing Testing conditional and loop constructs COMP 370
More information1 GB IO INTRODUCTION 1
1 GB IO INTRODUCTION 1 1. Introduction. This is GB IO, the input/output module used by all GraphBase routines to access data files. It doesn t actually do any output; but somehow input/output sounds like
More informationRACKET BASICS, ORDER OF EVALUATION, RECURSION 1
RACKET BASICS, ORDER OF EVALUATION, RECURSION 1 COMPUTER SCIENCE 61AS 1. What is functional programming? Give an example of a function below: Functional Programming In functional programming, you do not
More informationRationale for TR Extension to the programming language C. Decimal Floating-Point Arithmetic
WG14 N1161 Rationale for TR 24732 Extension to the programming language C Decimal Floating-Point Arithmetic Contents 1 Introduction... 1 1.1 Background... 1 1.2 The Arithmetic Model... 3 1.3 The Encodings...
More informationSummer May 11, 2010
Summer 2010 Department of Computer Science and Engineering York University Toronto May 11, 2010 1 / 40 What we did last time Overview of C to the language Program structure Types in C Operators in C IO
More informationVISUAL GUIDE to. RX Scripting. for Roulette Xtreme - System Designer 2.0. L J Howell UX Software Ver. 1.0
VISUAL GUIDE to RX Scripting for Roulette Xtreme - System Designer 2.0 L J Howell UX Software 2009 Ver. 1.0 TABLE OF CONTENTS INTRODUCTION...ii What is this book about?... iii How to use this book... iii
More informationLecture 4 CSE July 1992
Lecture 4 CSE 110 6 July 1992 1 More Operators C has many operators. Some of them, like +, are binary, which means that they require two operands, as in 4 + 5. Others are unary, which means they require
More informationComputer Labs: Debugging
Computer Labs: Debugging 2 o MIEIC Pedro F. Souto (pfs@fe.up.pt) October 29, 2012 Bugs and Debugging Problem To err is human This is specially true when the human is a programmer :( Solution There is none.
More informationDocumentation Nick Parlante, 1996.Free for non-commerical use.
Documentation Nick Parlante, 1996.Free for non-commerical use. A program expresses an algorithm to the computer. A program is clear or "readable" if it also does a good job of communicating the algorithm
More information1: Introduction to Object (1)
1: Introduction to Object (1) 김동원 2003.01.20 Overview (1) The progress of abstraction Smalltalk Class & Object Interface The hidden implementation Reusing the implementation Inheritance: Reusing the interface
More informationRule 1-3: Use white space to break a function into paragraphs. Rule 1-5: Avoid very long statements. Use multiple shorter statements instead.
Chapter 9: Rules Chapter 1:Style and Program Organization Rule 1-1: Organize programs for readability, just as you would expect an author to organize a book. Rule 1-2: Divide each module up into a public
More informationImproving Software Testability
Improving Software Testability George Yee, 1Z48-M Jan 14, 2000 1 Contents 1. Introduction 2. Improving Testability at Design Time 3. Improving Testability at Coding Time 4. Putting it into Practice 5.
More informationChapter IV Introduction to C for Java programmers
Chapter IV Introduction to C for Java programmers Now that we have seen the native instructions that a processor can execute, we will temporarily take a step up on the abstraction ladder and learn the
More informationVariables and Data Representation
You will recall that a computer program is a set of instructions that tell a computer how to transform a given set of input into a specific output. Any program, procedural, event driven or object oriented
More informationBlitz2D Newbies: Definitive Guide to Types by MutteringGoblin
Blitz2D Newbies: Definitive Guide to Types by MutteringGoblin Types are probably the hardest thing to understand about Blitz Basic. If you're using types for the first time, you've probably got an uneasy
More informationShould you know scanf and printf?
C-LANGUAGE INPUT & OUTPUT C-Language Output with printf Input with scanf and gets_s and Defensive Programming Copyright 2016 Dan McElroy Should you know scanf and printf? scanf is only useful in the C-language,
More informationLanguage Basics. /* The NUMBER GAME - User tries to guess a number between 1 and 10 */ /* Generate a random number between 1 and 10 */
Overview Language Basics This chapter describes the basic elements of Rexx. It discusses the simple components that make up the language. These include script structure, elements of the language, operators,
More informationChapter 1: Principles of Programming and Software Engineering
Chapter 1: Principles of Programming and Software Engineering Data Abstraction & Problem Solving with C++ Fifth Edition by Frank M. Carrano Software Engineering and Object-Oriented Design Coding without
More information