CMPSC 311- Introduction to Systems Programming Module: Arrays and Pointers

Size: px
Start display at page:

Download "CMPSC 311- Introduction to Systems Programming Module: Arrays and Pointers"

Transcription

1 CMPSC 311- Introduction to Systems Programming Module: Arrays and Pointers Professor Patrick McDaniel Fall 2014

2 Course notes Exam moved to Oct 1, 2014 Assignment #3 introduction section This Thur (9/25) 112 Walker Doughnuts! Late policy is up to 4 days Page

3 Arrays type name[size]; int scores[100]; example allocates 100 ints worth of memory initially, each array element contains garbage data an array does not know its own size sizeof(scores) is not reliable; only works in some situations recent versions of C allow the array size to be an expression int n=100; int scores[n]; // OK in C99 Page 3

4 Initializing and using arrays type name[size] = {value, value,..., value; allocates and array and fills it with supplied values if fewer values are given than the array size, fills rest with 0 name[index] = expression; sets the value of an array element int primes[6] = {2, 3, 5, 6, 11, 13; primes[3] = 7; primes[100] = 0; // smash! // 1000 zeroes int allzeroes[1000] = {0; Page 4

5 Setting array values (cont.) int val[3] = { 5, 5, 5 ; printf( "val [%d, %d, %d]\n", val[0], val[1], val[2] ); int val1[3] = { 0 ; printf( "val1 [%d, %d, %d]\n", val1[0], val1[1], val1[2] ); int val2[3] = { 1 ; printf( // "val2 Best [%d, approach %d, %d]\n", to val2[0], init all val2[1], values val2[2] ); int val4[3] = { [0... 2] = 1 ; int val3[3] = {; printf( "val3 [%d, %d, %d]\n", val3[0], val3[1], val3[2] ); int val4[3] = { [0... 2] = 1 ; printf( "val4 [%d, %d, %d]\n", val4[0], val4[1], val4[2] ); [5, 5, 5] [0, 0, 0] [1, 0, 0] [0, 0, 0] [1, 1, 1] Page 5

6 Multi-dimensional arrays type name[rows][columns] = {{values,..., {values; allocates a 2D array and fills it with predefined values // a 2 row, 3 column array of doubles double grid[2][3]; // a 3 row, 5 column array of ints int matrix[3][5] = { {0, 1, 2, 3, 4, {0, 2, 4, 6, 8, {1, 3, 5, 7, 9 ; grid[0][2] = (double) matrix[2][4]; // which val? matrix.c Page 6

7 Arrays as parameters It s tricky to use arrays as parameters arrays are effectively passed by reference (not copied) arrays do not know their own size int sumall(int a[]); // prototype declaration int main(int argc, char **argv) { int numbers[5] = {3, 4, 1, 7, 4; int sum = sumall(numbers); return 0; int sumall(int a[]) { int i, sum = 0; for (i = 0; i <...??? Page 7

8 Arrays as parameters Solution 1: declare the array size in the function problem: code isn t very flexible int sumall(int a[5]); // prototype declaration int main(int argc, char **argv) { int numbers[5] = {3, 4, 1, 7, 4; int sum = sumall(numbers); return 0; int sumall(int a[5]) Note: the size is not enforced! int sumall(int a[5]) { int i, sum = 0; for (i = 0; i < 5; i++) { sum += a[i]; return sum; Page 8

9 Arrays as parameters Solution 2: pass the size as a parameter int sumall(int a[], int size); // Array passed by reference int main(int argc, char **argv) { int numbers[5] = {3, 4, 1, 7, 4; int sum = sumall(numbers, 5); printf("sum is: %d\n", sum); return 0; int sumall(int a[], int size) { int i, sum = 0; for (i = 0; i <= size; i++) { sum += a[i]; return sum; arraysum.c // CAN YOU SPOT THE BUG? Page 9

10 Returning an array Local variables, including arrays, are stack allocated they disappear when a function returns therefore, local arrays can t be safely returned from functions int[] copyarray(int src[], int size) { int i, dst[size]; // OK in C99 for (i = 0; i < size; i++) { dst[i] = src[i]; return dst; // NO -- bug buggy_copyarray.c Page 10

11 Solution: an output parameter Create the returned array in the caller pass it as an output parameter to copyarray works because arrays are effectively passed by reference void copyarray(int src[], int dst[], int size) { int i; for (i = 0; i < size; i++) { dst[i] = src[i]; copyarray.c Page 11

12 OS and processes (redux) The OS lets you run multiple applications at once an application runs within an OS process the OS timeslices each CPU between runnable processes happens very fast; ~100 times per second! process 1 process 2 process N operating system Page 12

13 Processes and virtual memory OS gives each process the illusion of its own, private memory this is called the process address space contains the process virtual memory, visible only to it 32-bit pointers on 32- bit machine 64-bit pointers on 64- bit machine 0xFFFFFFFF" process address space" 0x " contains code, data, libraries, stack, etc. Page 13

14 Loading When the OS loads a program, it: creates an address space inspects the executable file to see what s in it (lazily) copies regions of the file into the right place in the address space does any final linking, relocation, or other needed preparation 0xFFFFFFFF" OS kernel [protected] stack shared libraries heap (malloc/free) read/write segment.data,.bss read-only segment.text,.rodata 0x " Page 14

15 Loading 0xFFFFFFFF" Process State/local variables OS kernel [protected] stack Code/Data for Libraries shared libraries Dynamic Data Static Data Code heap (malloc/free) read/write segment.data,.bss read-only segment.text,.rodata 0x " Page 15

16 The stack in detail Used to store data associated with function calls when you call a function, compiler-inserted code will allocate a stack frame to store: the function call arguments the address to return to local variables used by the function a few other pieces of bookkeeping int f(int p1, int p2) { int x; int a[3];... return x; offset! 24" 20" 16" 12" 8" 4" 0" contents! p2 p1 return address a[2] a[1] a[0] x a stack frame" Page 16

17 Stack example #include <stdio.h> #include <stdint.h> int showstack( int i, int j ) { int k = 2; int32_t l[2]; printf( "i is at [%p], size [%lu], value [%d]\n", &i, sizeof(i), i ); printf( "j is at [%p], size [%lu], value [%d]\n", &j, sizeof(j), j ); printf( "k is at [%p], size [%lu], value [%d]\n", &k, sizeof(k), k ); printf( "l is at [%p], size [%lu], value [%d]\n", &l[1], sizeof(l[1]), l[1] ); return( 0 ); int main( void ) { printf( "Hello world!\n" ); showstack( 3, 4 ); return( 0 ); Page 17

18 Stack example make gcc showstack.c -o showstack Hello world! i is at [0x7fffe345f0ec], size [4], value [3] j is at [0x7fffe345f0e8], size [4], value [4] k is at [0x7fffe345f0fc], size [4], value [2] l is at [0x7fffe345f104], size [4], value [0] mcdaniel@ubuntu:~/tmp/helloworld$... int showstack( int i, int j ) { int k = 2; int32_t l[2];... int main( void ) { printf( "Hello world!\n" ); showstack( 3, 4 ); return( 0 ); Page 18

19 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 19

20 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 20

21 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 21

22 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 22

23 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 23

24 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 24

25 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a g param heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 25

26 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a g param heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 26

27 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a g param heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 27

28 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 28

29 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 f p1, p2, x, a heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 29

30 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 30

31 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 g param heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 31

32 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 g param heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 32

33 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack main argc, argv, n1 heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 33

34 The stack in action OS kernel [protected] int main(int argc, char **argv) { int n1 = f(3, -5); n1 = g(n1); int f(int p1, int p2) { int x; int a[3];... x = g(a[2]); return x; int g(int param) { return param * 2; stack heap (malloc/free) read/write segment globals read-only segment (main, f, g) Page 34

35 Addresses and & &foo produces the virtual address of foo #include <stdio.h> int foo(int x) { return x+1; addresses.c int main(int argc, char **argv) { int x, y; int a[2]; printf("x is at %p\n", &x); printf("y is at %p\n", &y); printf("a[0] is at %p\n", &a[0]); printf("a[1] is at %p\n", &a[1]); printf("foo is at %p\n", &foo); printf("main is at %p\n", &main); return 0; Page 35

36 Pointers type *name; // declare a pointer type *name = address; // declare + initialize a pointer a pointer is a variable that contains a memory address it points to somewhere in the process virtual address space int main(int argc, char **argv) { int x = 42; int *p; // p is a pointer to an integer pointy.c p = &x; printf("x is %d\n", x); printf("&x is %p\n", &x); printf("p is %p\n", p); // p now stores the address of x return 0; Page 36

37 A stylistic choice C gives you flexibility in how you declare pointers one way can lead to visual trouble when declaring multiple pointers on a single line the other way is what I prefer int* p1; int *p2; // I prefer int* p1, p2; // bug?; equivalent to int *p1; int p2; int* p1, * p2; // correct or int *p1, *p2; // correct, preferred Page 37

38 Dereferencing pointers *pointer // dereference a pointer *pointer = value; // dereference / assign dereference: access the memory referred to by a pointer #include <stdio.h> deref.c int main(int argc, char **argv) { int x = 42; int *p; // p is a pointer to an integer p = &x; // p now stores the address of x printf("x is %d\n", x); *p = 99; printf("x is %d\n", x); return 0; Page 38

39 & and * &foo // address of foo *pointer // dereference a pointer *pointer = value; // dereference / assign deref.c int x = 42; // x now contains the value 42 int *p; // p is a pointer to an integer p = &x; // p now contains the address of x printf("x is %d\n", x); *p = 99; // store 99 where p points to printf("x is %d\n"); Page 39

40 Something curious Let s try running this program several times: #include <stdio.h> asr.c int main(int argc, char **argv) { int x = 1; int *p = &x; printf("&x: %p; p: %p; &p: %p\n", &x, p, &p); return 0; [butler]>./asr &x: 0xbfa521dc; p: 0xbfa521dc; &p: 0xbfa521d8 [butler]>./asr &x: 0xbf836f5c; p: 0xbf836f5c; &p: 0xbf836f58 [butler]>./asr &x: 0xbfea39dc; p: 0xbfea39dc; &p: 0xbfea39d8 Page 40

41 ASLR Linux uses address-space randomization for added security linux randomizes: base of stack shared library (mmap) location makes stack-based buffer overflow attacks tougher makes debugging tougher google disable linux address space randomization 0xFFFFFFFF 0x OS kernel [protected] stack shared libraries heap (malloc/free) read/write segment.data,.bss read-only segment.text,.rodata Page 41

CSE 333 Lecture 3 - arrays, memory, pointers

CSE 333 Lecture 3 - arrays, memory, pointers CSE 333 Lecture 3 - arrays, memory, pointers Steve Gribble Department of Computer Science & Engineering University of Washington Administrivia HW 0.5 (a 4-question survey) - out today, due Monday HW 1.0

More information

CSE 333 Lecture 2 - arrays, memory, pointers

CSE 333 Lecture 2 - arrays, memory, pointers CSE 333 Lecture 2 - arrays, memory, pointers Hal Perkins Department of Computer Science & Engineering University of Washington Administrivia 1 ex0 was due 30 minutes ago! Solution posted after class -

More information

Memory and Arrays. CSE 333 Spring Instructor: Justin Hsia

Memory and Arrays. CSE 333 Spring Instructor: Justin Hsia Memory and Arrays CSE 333 Spring 2018 Instructor: Justin Hsia Teaching Assistants: Danny Allen Dennis Shao Eddie Huang Kevin Bi Jack Xu Matthew Neldam Michael Poulain Renshu Gu Robby Marver Waylon Huang

More information

Systems Programming and Computer Architecture ( )

Systems Programming and Computer Architecture ( ) Systems Group Department of Computer Science ETH Zürich Systems Programming and Computer Architecture (252-0061-00) Timothy Roscoe Herbstsemester 2016 1 4: Pointers Computer Architecture and Systems Programming

More information

CMPSC 311- Introduction to Systems Programming Module: Introduction to C

CMPSC 311- Introduction to Systems Programming Module: Introduction to C CMPSC 311- Introduction to Systems Programming Module: Introduction to C Professor Patrick McDaniel Fall 2015 Building HW1 You are provided with a Makefile that will assist in making your program. You

More information

CS 31: Intro to Systems Pointers and Memory. Martin Gagne Swarthmore College February 16, 2016

CS 31: Intro to Systems Pointers and Memory. Martin Gagne Swarthmore College February 16, 2016 CS 31: Intro to Systems Pointers and Memory Martin Gagne Swarthmore College February 16, 2016 So we declared a pointer How do we make it point to something? 1. Assign it the address of an existing variable

More information

Pointers, Pointers, Pointers

Pointers, Pointers, Pointers Pointers, Pointers, Pointers CSE 333 Autumn 2018 Instructor: Hal Perkins Teaching Assistants: Tarkan Al-Kazily Renshu Gu Trais McGaha Harshita Neti Thai Pham Forrest Timour Soumya Vasisht Yifan Xu Administriia

More information

High-performance computing and programming Intro to C on Unix/Linux. Uppsala universitet

High-performance computing and programming Intro to C on Unix/Linux. Uppsala universitet High-performance computing and programming Intro to C on Unix/Linux IT Uppsala universitet What is C? An old imperative language that remains rooted close to the hardware C is relatively small and easy

More information

Arrays and Pointers in C. Alan L. Cox

Arrays and Pointers in C. Alan L. Cox Arrays and Pointers in C Alan L. Cox alc@rice.edu Objectives Be able to use arrays, pointers, and strings in C programs Be able to explain the representation of these data types at the machine level, including

More information

The output: The address of i is 0xbf85416c. The address of main is 0x80483e4. arrays.c. 1 #include <stdio.h> 3 int main(int argc, char **argv) 4 {

The output: The address of i is 0xbf85416c. The address of main is 0x80483e4. arrays.c. 1 #include <stdio.h> 3 int main(int argc, char **argv) 4 { Memory A bit is a binary digit, either 0 or 1. A byte is eight bits, and can thus represent 256 unique values, such as 00000000 and 10010110. Computer scientists often think in terms of hexadecimal, rather

More information

Pointers. Pointers. Pointers (cont) CS 217

Pointers. Pointers. Pointers (cont) CS 217 Pointers CS 217 Pointers Variables whose values are the addresses of variables Operations address of (reference) & indirection (dereference) * arithmetic +, - Declaration mimics use char *p; *p is a char,

More information

Memory Corruption 101 From Primitives to Exploit

Memory Corruption 101 From Primitives to Exploit Memory Corruption 101 From Primitives to Exploit Created by Nick Walker @ MWR Infosecurity / @tel0seh What is it? A result of Undefined Behaviour Undefined Behaviour A result of executing computer code

More information

CSE 303: Concepts and Tools for Software Development

CSE 303: Concepts and Tools for Software Development CSE 303: Concepts and Tools for Software Development Hal Perkins Winter 2009 Lecture 7 Introduction to C: The C-Level of Abstraction CSE 303 Winter 2009, Lecture 7 1 Welcome to C Compared to Java, in rough

More information

SOFTWARE Ph.D. Qualifying Exam Spring Consider the following C program which consists of two function definitions including the main function.

SOFTWARE Ph.D. Qualifying Exam Spring Consider the following C program which consists of two function definitions including the main function. (i) (5 pts.) SOFTWARE Ph.D. Qualifying Exam Spring 2018 Consider the following C program which consists of two function definitions including the main function. #include int g(int z) { int y

More information

CS 261 Fall C Introduction. Variables, Memory Model, Pointers, and Debugging. Mike Lam, Professor

CS 261 Fall C Introduction. Variables, Memory Model, Pointers, and Debugging. Mike Lam, Professor CS 261 Fall 2017 Mike Lam, Professor C Introduction Variables, Memory Model, Pointers, and Debugging The C Language Systems language originally developed for Unix Imperative, compiled language with static

More information

unsigned char memory[] STACK ¼ 0x xC of address space globals function KERNEL code local variables

unsigned char memory[] STACK ¼ 0x xC of address space globals function KERNEL code local variables Graded assignment 0 will be handed out in section Assignment 1 Not that bad Check your work (run it through the compiler) Factorial Program Prints out ENTERING, LEAVING, and other pointers unsigned char

More information

Programming in C. Pointers and Arrays

Programming in C. Pointers and Arrays Programming in C Pointers and Arrays NEXT SET OF SLIDES FROM DENNIS FREY S FALL 2011 CMSC313 http://www.csee.umbc.edu/courses/undergraduate/313/fall11/" Pointers and Arrays In C, there is a strong relationship

More information

Array Initialization

Array Initialization Array Initialization Array declarations can specify initializations for the elements of the array: int primes[10] = { 2, 3, 5, 7, 11, 13, 17, 19, 23, 29 ; initializes primes[0] to 2, primes[1] to 3, primes[2]

More information

UNDEFINED BEHAVIOR IS AWESOME

UNDEFINED BEHAVIOR IS AWESOME UNDEFINED BEHAVIOR IS AWESOME Piotr Padlewski piotr.padlewski@gmail.com, @PiotrPadlewski ABOUT MYSELF Currently working in IIIT developing C++ tooling like clang-tidy and studying on University of Warsaw.

More information

Pointers, Pointers, Pointers

Pointers, Pointers, Pointers Pointers, Pointers, Pointers CSE 333 Summer 2018 Instructor: Hal Perkins Teaching Assistants: Renshu Gu William Kim Soumya Vasisht Administrivia v Exercise 2 out today and due Monday morning v Exercise

More information

Announcements. CSCI 334: Principles of Programming Languages. Lecture 18: C/C++ Announcements. Announcements. Instructor: Dan Barowy

Announcements. CSCI 334: Principles of Programming Languages. Lecture 18: C/C++ Announcements. Announcements. Instructor: Dan Barowy CSCI 334: Principles of Programming Languages Lecture 18: C/C++ Homework help session will be tomorrow from 7-9pm in Schow 030A instead of on Thursday. Instructor: Dan Barowy HW6 and HW7 solutions We only

More information

Processes. Johan Montelius KTH

Processes. Johan Montelius KTH Processes Johan Montelius KTH 2017 1 / 47 A process What is a process?... a computation a program i.e. a sequence of operations a set of data structures a set of registers means to interact with other

More information

CPSC 213, Winter 2016, Term 2 Final Exam Solution Date: April 19, 2017; Instructor: Mike Feeley and Alan Wagner

CPSC 213, Winter 2016, Term 2 Final Exam Solution Date: April 19, 2017; Instructor: Mike Feeley and Alan Wagner CPSC 213, Winter 2016, Term 2 Final Exam Solution Date: April 19, 2017; Instructor: Mike Feeley and Alan Wagner 1 (4 marks) Variables and Memory. Consider the following code running on 32-bit, big-endian

More information

A process. the stack

A process. the stack A process Processes Johan Montelius What is a process?... a computation KTH 2017 a program i.e. a sequence of operations a set of data structures a set of registers means to interact with other processes

More information

Hacking in C. Pointers. Radboud University, Nijmegen, The Netherlands. Spring 2019

Hacking in C. Pointers. Radboud University, Nijmegen, The Netherlands. Spring 2019 Hacking in C Pointers Radboud University, Nijmegen, The Netherlands Spring 2019 Allocation of multiple variables Consider the program main(){ char x; int i; short s; char y;... } What will the layout of

More information

Pointers. Pointer References

Pointers. Pointer References Pointers Pointers are variables whose values are the addresses of other variables Basic operations address of (reference) indirection (dereference) Suppose x and y are integers, p is a pointer to an integer:

More information

Common Misunderstandings from Exam 1 Material

Common Misunderstandings from Exam 1 Material Common Misunderstandings from Exam 1 Material Kyle Dewey Stack and Heap Allocation with Pointers char c = c ; char* p1 = malloc(sizeof(char)); char** p2 = &p1; Where is c allocated? Where is p1 itself

More information

FUNCTIONS POINTERS. Pointers. Functions

FUNCTIONS POINTERS. Pointers. Functions Functions Pointers FUNCTIONS C allows a block of code to be separated from the rest of the program and named. These blocks of code or modules are called functions. Functions can be passed information thru

More information

Introduction to C. Robert Escriva. Cornell CS 4411, August 30, Geared toward programmers

Introduction to C. Robert Escriva. Cornell CS 4411, August 30, Geared toward programmers Introduction to C Geared toward programmers Robert Escriva Slide heritage: Alin Dobra Niranjan Nagarajan Owen Arden Cornell CS 4411, August 30, 2010 1 Why C? 2 A Quick Example 3 Programmer s Responsibilities

More information

Memory Management. a C view. Dr Alun Moon KF5010. Computer Science. Dr Alun Moon (Computer Science) Memory Management KF / 24

Memory Management. a C view. Dr Alun Moon KF5010. Computer Science. Dr Alun Moon (Computer Science) Memory Management KF / 24 Memory Management a C view Dr Alun Moon Computer Science KF5010 Dr Alun Moon (Computer Science) Memory Management KF5010 1 / 24 The Von Neumann model Memory Architecture One continuous address space Program

More information

CSE 303 Midterm Exam

CSE 303 Midterm Exam CSE 303 Midterm Exam October 29, 2008 Name Sample Solution The exam is closed book, except that you may have a single page of hand written notes for reference. If you don t remember the details of how

More information

CSE 333 Midterm Exam 5/10/13

CSE 333 Midterm Exam 5/10/13 Name There are 5 questions worth a total of 100 points. Please budget your time so you get to all of the questions. Keep your answers brief and to the point. The exam is closed book, closed notes, closed

More information

C Introduction. Comparison w/ Java, Memory Model, and Pointers

C Introduction. Comparison w/ Java, Memory Model, and Pointers CS 261 Fall 2018 Mike Lam, Professor C Introduction Comparison w/ Java, Memory Model, and Pointers Please go to socrative.com on your phone or laptop, choose student login and join room LAMJMU The C Language

More information

Dynamic memory allocation

Dynamic memory allocation Dynamic memory allocation outline Memory allocation functions Array allocation Matrix allocation Examples Memory allocation functions (#include ) malloc() Allocates a specified number of bytes

More information

Pointers. September 13, 2017 Hassan Khosravi / Geoffrey Tien 1

Pointers. September 13, 2017 Hassan Khosravi / Geoffrey Tien 1 Pointers September 13, 2017 Hassan Khosravi / Geoffrey Tien 1 Multi-dimensional arrays A two-dimensional array is specified using two indices First index denotes the row, second index denotes column int

More information

Lecture 04 Introduction to pointers

Lecture 04 Introduction to pointers Lecture 04 Introduction to pointers A pointer is an address in the memory. One of the unique advantages of using C is that it provides direct access to a memory location through its address. A variable

More information

Arrays and Pointers. CSE 2031 Fall November 11, 2013

Arrays and Pointers. CSE 2031 Fall November 11, 2013 Arrays and Pointers CSE 2031 Fall 2013 November 11, 2013 1 Arrays l Grouping of data of the same type. l Loops commonly used for manipulation. l Programmers set array sizes explicitly. 2 Arrays: Example

More information

COMP 2355 Introduction to Systems Programming

COMP 2355 Introduction to Systems Programming COMP 2355 Introduction to Systems Programming Christian Grothoff christian@grothoff.org http://grothoff.org/christian/ 1 Pointers Pointers denote addresses in memory In C types, the * represents the use

More information

Exercise Session 2 Systems Programming and Computer Architecture

Exercise Session 2 Systems Programming and Computer Architecture Systems Group Department of Computer Science ETH Zürich Exercise Session 2 Systems Programming and Computer Architecture Herbstsemester 216 Agenda Linux vs. Windows Working with SVN Exercise 1: bitcount()

More information

Kurt Schmidt. October 30, 2018

Kurt Schmidt. October 30, 2018 to Structs Dept. of Computer Science, Drexel University October 30, 2018 Array Objectives to Structs Intended audience: Student who has working knowledge of Python To gain some experience with a statically-typed

More information

Fundamental of Programming (C)

Fundamental of Programming (C) Borrowed from lecturer notes by Omid Jafarinezhad Fundamental of Programming (C) Lecturer: Vahid Khodabakhshi Lecture 9 Pointer Department of Computer Engineering 1/46 Outline Defining and using Pointers

More information

MPATE-GE 2618: C Programming for Music Technology. Unit 4.1

MPATE-GE 2618: C Programming for Music Technology. Unit 4.1 MPATE-GE 2618: C Programming for Music Technology Unit 4.1 Memory Memory in the computer can be thought of as a long string of consecutive bytes. Each byte has a corresponding address. When we declare

More information

Overview (1A) Young Won Lim 9/14/17

Overview (1A) Young Won Lim 9/14/17 Overview (1A) Copyright (c) 2009-2017 Young W. Lim. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later

More information

CSE 333. Lecture 4 - malloc, free, struct, typedef. Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington

CSE 333. Lecture 4 - malloc, free, struct, typedef. Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington CSE 333 Lecture 4 - malloc, free, struct, typedef Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington Administrivia 1 New exercise out today, due Friday morning

More information

ntroduction to C CS 2022: ntroduction to C nstructor: Hussam Abu-Libdeh (based on slides by Saikat Guha) Fall 2011, Lecture 1 ntroduction to C CS 2022, Fall 2011, Lecture 1 History of C Writing code in

More information

ELEC 377 C Programming Tutorial. ELEC Operating Systems

ELEC 377 C Programming Tutorial. ELEC Operating Systems ELE 377 Programming Tutorial Outline! Short Introduction! History & Memory Model of! ommon Errors I have seen over the years! Work through a linked list example on the board! - uses everything I talk about

More information

CS240: Programming in C

CS240: Programming in C CS240: Programming in C Lecture 5: Functions. Scope of variables. Program structure. Cristina Nita-Rotaru Lecture 5/ Fall 2013 1 Functions: Explicit declaration Declaration, definition, use, order matters.

More information

Overview (1A) Young Won Lim 9/9/17

Overview (1A) Young Won Lim 9/9/17 Overview (1A) Copyright (c) 2009-2017 Young W. Lim. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later

More information

Chapter 11 Introduction to Programming in C

Chapter 11 Introduction to Programming in C Chapter 11 Introduction to Programming in C C: A High-Level Language Gives symbolic names to values don t need to know which register or memory location Provides abstraction of underlying hardware operations

More information

CSE 333 Lecture 2 Memory

CSE 333 Lecture 2 Memory CSE 333 Lecture 2 Memory John Zahorjan Department of Computer Science & Engineering University of Washington Today s goals - some terminology - review of memory resources - reserving memory - type checking

More information

CS 326 Operating Systems C Programming. Greg Benson Department of Computer Science University of San Francisco

CS 326 Operating Systems C Programming. Greg Benson Department of Computer Science University of San Francisco CS 326 Operating Systems C Programming Greg Benson Department of Computer Science University of San Francisco Why C? Fast (good optimizing compilers) Not too high-level (Java, Python, Lisp) Not too low-level

More information

Arrays and Pointers. Arrays. Arrays: Example. Arrays: Definition and Access. Arrays Stored in Memory. Initialization. EECS 2031 Fall 2014.

Arrays and Pointers. Arrays. Arrays: Example. Arrays: Definition and Access. Arrays Stored in Memory. Initialization. EECS 2031 Fall 2014. Arrays Arrays and Pointers l Grouping of data of the same type. l Loops commonly used for manipulation. l Programmers set array sizes explicitly. EECS 2031 Fall 2014 November 11, 2013 1 2 Arrays: Example

More information

CS 31: Intro to Systems Pointers and Memory. Kevin Webb Swarthmore College October 2, 2018

CS 31: Intro to Systems Pointers and Memory. Kevin Webb Swarthmore College October 2, 2018 CS 31: Intro to Systems Pointers and Memory Kevin Webb Swarthmore College October 2, 2018 Overview How to reference the location of a variable in memory Where variables are placed in memory How to make

More information

CSE 124 Discussion (10/3) C/C++ Basics

CSE 124 Discussion (10/3) C/C++ Basics CSE 124 Discussion (10/3) C/C++ Basics Topics - main() function - Compiling with gcc/makefile - Primitives - Structs/Enums - Function calls/loops - C++ Classes/stdtl - Pointers/Arrays - Memory allocation/freeing

More information

Overview (1A) Young Won Lim 9/25/17

Overview (1A) Young Won Lim 9/25/17 Overview (1A) Copyright (c) 2009-2017 Young W. Lim. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later

More information

CS 223: Data Structures and Programming Techniques. Exam 2

CS 223: Data Structures and Programming Techniques. Exam 2 CS 223: Data Structures and Programming Techniques. Exam 2 Instructor: Jim Aspnes Work alone. Do not use any notes or books. You have approximately 75 minutes to complete this exam. Please write your answers

More information

Lecture 03 Bits, Bytes and Data Types

Lecture 03 Bits, Bytes and Data Types Lecture 03 Bits, Bytes and Data Types Computer Languages A computer language is a language that is used to communicate with a machine. Like all languages, computer languages have syntax (form) and semantics

More information

CMSC 313 COMPUTER ORGANIZATION & ASSEMBLY LANGUAGE PROGRAMMING LECTURE 13, FALL 2012

CMSC 313 COMPUTER ORGANIZATION & ASSEMBLY LANGUAGE PROGRAMMING LECTURE 13, FALL 2012 CMSC 313 COMPUTER ORGANIZATION & ASSEMBLY LANGUAGE PROGRAMMING LECTURE 13, FALL 2012 TOPICS TODAY Project 5 Pointer Basics Pointers and Arrays Pointers and Strings POINTER BASICS Java Reference In Java,

More information

ECEN 449 Microprocessor System Design. Review of C Programming

ECEN 449 Microprocessor System Design. Review of C Programming ECEN 449 Microprocessor System Design Review of C Programming 1 Objectives of this Lecture Unit Review C programming basics Refresh es programming g skills s 2 1 Basic C program structure # include

More information

Windows architecture. user. mode. Env. subsystems. Executive. Device drivers Kernel. kernel. mode HAL. Hardware. Process B. Process C.

Windows architecture. user. mode. Env. subsystems. Executive. Device drivers Kernel. kernel. mode HAL. Hardware. Process B. Process C. Structure Unix architecture users Functions of the System tools (shell, editors, compilers, ) standard library System call Standard library (printf, fork, ) OS kernel: processes, memory management, file

More information

CS C Primer. Tyler Szepesi. January 16, 2013

CS C Primer. Tyler Szepesi. January 16, 2013 January 16, 2013 Topics 1 Why C? 2 Data Types 3 Memory 4 Files 5 Endianness 6 Resources Why C? C is exteremely flexible and gives control to the programmer Allows users to break rigid rules, which are

More information

APT Session 4: C. Software Development Team Laurence Tratt. 1 / 14

APT Session 4: C. Software Development Team Laurence Tratt. 1 / 14 APT Session 4: C Laurence Tratt Software Development Team 2017-11-10 1 / 14 http://soft-dev.org/ What to expect from this session 1 C. 2 / 14 http://soft-dev.org/ Prerequisites 1 Install either GCC or

More information

Memory and Addresses. Pointers in C. Memory is just a sequence of byte-sized storage devices.

Memory and Addresses. Pointers in C. Memory is just a sequence of byte-sized storage devices. Memory and Addresses Memory is just a sequence of byte-sized storage devices. 1 The bytes are assigned numeric addresses, starting with zero, just like the indexing of the cells of an array. It is the

More information

Introduction to C. Sean Ogden. Cornell CS 4411, August 30, Geared toward programmers

Introduction to C. Sean Ogden. Cornell CS 4411, August 30, Geared toward programmers Introduction to C Geared toward programmers Sean Ogden Slide heritage: Alin Dobra Niranjan Nagarajan Owen Arden Robert Escriva Zhiyuan Teo Ayush Dubey Cornell CS 4411, August 30, 2013 Administrative Information

More information

ECE264 Fall 2013 Exam 1, September 24, 2013

ECE264 Fall 2013 Exam 1, September 24, 2013 ECE264 Fall 2013 Exam 1, September 24, 2013 In signing this statement, I hereby certify that the work on this exam is my own and that I have not copied the work of any other student while completing it.

More information

Introduction to C. Ayush Dubey. Cornell CS 4411, August 31, Geared toward programmers

Introduction to C. Ayush Dubey. Cornell CS 4411, August 31, Geared toward programmers Introduction to C Geared toward programmers Ayush Dubey Slide heritage: Alin Dobra Niranjan Nagarajan Owen Arden Robert Escriva Zhiyuan Teo Cornell CS 4411, August 31, 2012 Administrative Information Outline

More information

BIL 104E Introduction to Scientific and Engineering Computing. Lecture 14

BIL 104E Introduction to Scientific and Engineering Computing. Lecture 14 BIL 104E Introduction to Scientific and Engineering Computing Lecture 14 Because each C program starts at its main() function, information is usually passed to the main() function via command-line arguments.

More information

CS 322 Operating Systems Practice Midterm Questions

CS 322 Operating Systems Practice Midterm Questions ! CS 322 Operating Systems 1. Processes go through the following states in their lifetime. time slice ends Consider the following events and answer the questions that follow. Assume there are 5 processes,

More information

Chapter 11 Introduction to Programming in C

Chapter 11 Introduction to Programming in C Chapter 11 Introduction to Programming in C C: A High-Level Language Gives symbolic names to values don t need to know which register or memory location Provides abstraction of underlying hardware operations

More information

CSE 333 Midterm Exam 7/27/15 Sample Solution

CSE 333 Midterm Exam 7/27/15 Sample Solution Question 1. (24 points) C programming. In this problem we want to implement a set of strings in C. A set is represented as a linked list of strings with no duplicate values. The nodes in the list are defined

More information

CSci 4061 Introduction to Operating Systems. Programs in C/Unix

CSci 4061 Introduction to Operating Systems. Programs in C/Unix CSci 4061 Introduction to Operating Systems Programs in C/Unix Today Basic C programming Follow on to recitation Structure of a C program A C program consists of a collection of C functions, structs, arrays,

More information

Procedures, Parameters, Values and Variables. Steven R. Bagley

Procedures, Parameters, Values and Variables. Steven R. Bagley Procedures, Parameters, Values and Variables Steven R. Bagley Recap A Program is a sequence of statements (instructions) Statements executed one-by-one in order Unless it is changed by the programmer e.g.

More information

CSCI-243 Exam 1 Review February 22, 2015 Presented by the RIT Computer Science Community

CSCI-243 Exam 1 Review February 22, 2015 Presented by the RIT Computer Science Community CSCI-243 Exam 1 Review February 22, 2015 Presented by the RIT Computer Science Community http://csc.cs.rit.edu History and Evolution of Programming Languages 1. Explain the relationship between machine

More information

ECEN 449 Microprocessor System Design. Review of C Programming. Texas A&M University

ECEN 449 Microprocessor System Design. Review of C Programming. Texas A&M University ECEN 449 Microprocessor System Design Review of C Programming 1 Objectives of this Lecture Unit Review C programming basics Refresh programming skills 2 Basic C program structure # include main()

More information

CS270 Homework 5 (HW5)

CS270 Homework 5 (HW5) Name: Date: CS270 Homework 5 (HW5) Due Thursday, Nov 21 (start of class) Homework and programming assignments are to be done individually. Goals To understand C pointers and structs, and functions and

More information

Arrays, Strings, & Pointers

Arrays, Strings, & Pointers Arrays, Strings, & Pointers Alexander Nelson August 31, 2018 University of Arkansas - Department of Computer Science and Computer Engineering Arrays, Strings, & Pointers Arrays, Strings, & Pointers are

More information

Introduction. This project will focus primarily on processes.

Introduction. This project will focus primarily on processes. Project 2 Processes Introduction This project will focus primarily on processes. In this project, you will become familiar with: 1. Locks for kernel-level data structures; concurrency. 2. Implementing

More information

Lab 1: Introduction to C Programming

Lab 1: Introduction to C Programming CS342 Computer Security Handout # 2 Prof. Lyn Turbak September 13, 2010 Wellesley College Lab 1: Introduction to C Programming Reading: Hacking, 0x210 0x240 Overview Later in the course, we will study

More information

Today s class. Review of more C Operating system overview. Informationsteknologi

Today s class. Review of more C Operating system overview. Informationsteknologi Today s class Review of more C Operating system overview Monday, September 10, 2007 Computer Systems/Operating Systems - Class 3 1 Review of more C File handling Open a file using fopen Returns a file

More information

Introduction to C. Zhiyuan Teo. Cornell CS 4411, August 26, Geared toward programmers

Introduction to C. Zhiyuan Teo. Cornell CS 4411, August 26, Geared toward programmers Introduction to C Geared toward programmers Zhiyuan Teo Slide heritage: Alin Dobra Niranjan Nagarajan Owen Arden Robert Escriva Cornell CS 4411, August 26, 2011 1 Administrative Information 2 Why C? 3

More information

Outline. Computer programming. Debugging. What is it. Debugging. Hints. Debugging

Outline. Computer programming. Debugging. What is it. Debugging. Hints. Debugging Outline Computer programming Debugging Hints Gathering evidence Common C errors "Education is a progressive discovery of our own ignorance." Will Durant T.U. Cluj-Napoca - Computer Programming - lecture

More information

Introduction to OS Processes in Unix, Linux, and Windows MOS 2.1 Mahmoud El-Gayyar

Introduction to OS Processes in Unix, Linux, and Windows MOS 2.1 Mahmoud El-Gayyar Introduction to OS Processes in Unix, Linux, and Windows MOS 2.1 Mahmoud El-Gayyar elgayyar@ci.suez.edu.eg Mahmoud El-Gayyar / Introduction to OS 1 Processes in Unix, Linux, and Windows Unix pre-empted

More information

CSC 438 Systems and Software Security, Spring 2014 Instructor: Dr. Natarajan Meghanathan Question Bank for Module 6: Software Security Attacks

CSC 438 Systems and Software Security, Spring 2014 Instructor: Dr. Natarajan Meghanathan Question Bank for Module 6: Software Security Attacks CSC 438 Systems and Software Security, Spring 2014 Instructor: Dr. Natarajan Meghanathan Question Bank for Module 6: Software Security Attacks 1) What will be the output of the following C program when

More information

5) Attacker causes damage Different to gaining control. For example, the attacker might quit after gaining control.

5) Attacker causes damage Different to gaining control. For example, the attacker might quit after gaining control. Feb 23, 2009 CSE, 409/509 Mitigation of Bugs, Life of an exploit 1) Bug inserted into code 2) Bug passes testing 3) Attacker triggers bug 4) The Attacker gains control of the program 5) Attacker causes

More information

Programming in C - Part 2

Programming in C - Part 2 Programming in C - Part 2 CPSC 457 Mohammad Reza Zakerinasab May 11, 2016 These slides are forked from slides created by Mike Clark Where to find these slides and related source code? http://goo.gl/k1qixb

More information

CSE 333 Midterm Exam Sample Solution 5/10/13

CSE 333 Midterm Exam Sample Solution 5/10/13 Question 1. (18 points) Consider these two C files: a.c void f(int p); int main() { f(17); return 0; b.c void f(char *p) { *p = 'x'; (a) Why is the program made from a.c and b.c incorrect? What would you

More information

Q1: /20 Q2: /30 Q3: /24 Q4: /26. Total: /100

Q1: /20 Q2: /30 Q3: /24 Q4: /26. Total: /100 ECE 2035(B) Programming for Hardware/Software Systems Fall 2013 Exam Two October 22 nd 2013 Name: Q1: /20 Q2: /30 Q3: /24 Q4: /26 Total: /100 1/6 For functional call related questions, let s assume the

More information

Scope: Global and Local. Concept of Scope of Variable

Scope: Global and Local. Concept of Scope of Variable Concept of Scope of Variable : Computer Architecture I Instructor: Prof. Bhagi Narahari Dept. of Computer Science Course URL: www.seas.gwu.edu/~bhagiweb/cs135/ In assembly, who has access to a memory location/variable?

More information

Types. C Types. Floating Point. Derived. fractional part. no fractional part. Boolean Character Integer Real Imaginary Complex

Types. C Types. Floating Point. Derived. fractional part. no fractional part. Boolean Character Integer Real Imaginary Complex Types C Types Void Integral Floating Point Derived Boolean Character Integer Real Imaginary Complex no fractional part fractional part 2 tj Types C Types Derived Function Array Pointer Structure Union

More information

CS 220: Introduction to Parallel Computing. Beginning C. Lecture 2

CS 220: Introduction to Parallel Computing. Beginning C. Lecture 2 CS 220: Introduction to Parallel Computing Beginning C Lecture 2 Today s Schedule More C Background Differences: C vs Java/Python The C Compiler HW0 8/25/17 CS 220: Parallel Computing 2 Today s Schedule

More information

CS61, Fall 2012 Section 2 Notes

CS61, Fall 2012 Section 2 Notes CS61, Fall 2012 Section 2 Notes (Week of 9/24-9/28) 0. Get source code for section [optional] 1: Variable Duration 2: Memory Errors Common Errors with memory and pointers Valgrind + GDB Common Memory Errors

More information

FORM 2 (Please put your name and form # on the scantron!!!!) CS 161 Exam II:

FORM 2 (Please put your name and form # on the scantron!!!!) CS 161 Exam II: FORM 2 (Please put your name and form # on the scantron!!!!) CS 161 Exam II: True (A)/False(B) (2 pts each): 1. The declaration below declares three pointer variables of type pointer to double that is

More information

ESC101N: Fundamentals of Computing End-sem st semester

ESC101N: Fundamentals of Computing End-sem st semester ESC101N: Fundamentals of Computing End-sem 2010-11 1st semester Instructor: Arnab Bhattacharya 8:00-11:00am, 15th November, 2010 Instructions 1. Please write your name, roll number and section below. 2.

More information

Lab 3. Pointers Programming Lab (Using C) XU Silei

Lab 3. Pointers Programming Lab (Using C) XU Silei Lab 3. Pointers Programming Lab (Using C) XU Silei slxu@cse.cuhk.edu.hk Outline What is Pointer Memory Address & Pointers How to use Pointers Pointers Assignments Call-by-Value & Call-by-Address Functions

More information

ECE 462 Fall 2011, Third Exam

ECE 462 Fall 2011, Third Exam ECE 462 Fall 2011, Third Exam DO NOT START WORKING ON THIS UNTIL TOLD TO DO SO. You have until 9:20 to take this exam. Your exam should have 12 pages total (including this cover sheet). Please let Prof.

More information

Buffer overflow background

Buffer overflow background and heap buffer background Comp Sci 3600 Security Heap Outline and heap buffer Heap 1 and heap 2 3 buffer 4 5 Heap Outline and heap buffer Heap 1 and heap 2 3 buffer 4 5 Heap Address Space and heap buffer

More information

Review: C Strings. A string in C is just an array of characters. Lecture #4 C Strings, Arrays, & Malloc

Review: C Strings. A string in C is just an array of characters. Lecture #4 C Strings, Arrays, & Malloc CS61C L4 C Pointers (1) inst.eecs.berkeley.edu/~cs61c CS61C : Machine Structures Lecture #4 C Strings, Arrays, & Malloc Albert Chae Instructor 2008-06-26 Review: C Strings A string in C is just an array

More information

Structured Programming. Functions and Structured Programming. Functions. Variables

Structured Programming. Functions and Structured Programming. Functions. Variables Structured Programming Functions and Structured Programming Structured programming is a problem-solving strategy and a programming methodology. The construction of a program should embody topdown design

More information

CS201 - Lecture 1 The C Programming Language

CS201 - Lecture 1 The C Programming Language CS201 - Lecture 1 The C Programming Language RAOUL RIVAS PORTLAND STATE UNIVERSITY History of the C Language The C language was invented in 1970 by Dennis Ritchie Dennis Ritchie and Ken Thompson were employees

More information

Design 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 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 information