CMPSC 311- Introduction to Systems Programming Module: Arrays and Pointers
|
|
- Benjamin Palmer
- 6 years ago
- Views:
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 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 informationCSE 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 informationMemory 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 informationSystems 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 informationCMPSC 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 informationCS 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 informationPointers, 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 informationHigh-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 informationArrays 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 informationThe 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 informationPointers. 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 informationMemory 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 informationCSE 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 informationSOFTWARE 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 informationCS 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 informationunsigned 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 informationProgramming 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 informationArray 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 informationUNDEFINED 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 informationPointers, 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 informationAnnouncements. 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 informationProcesses. 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 informationCPSC 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 informationA 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 informationHacking 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 informationPointers. 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 informationCommon 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 informationFUNCTIONS 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 informationIntroduction 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 informationMemory 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 informationCSE 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 informationCSE 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 informationC 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 informationDynamic 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 informationPointers. 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 informationLecture 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 informationArrays 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 informationCOMP 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 informationExercise 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 informationKurt 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 informationFundamental 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 informationMPATE-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 informationOverview (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 informationCSE 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 informationntroduction 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 informationELEC 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 informationCS240: 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 informationOverview (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 informationChapter 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 informationCSE 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 informationCS 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 informationArrays 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 informationCS 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 informationCSE 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 informationOverview (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 informationCS 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 informationLecture 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 informationCMSC 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 informationECEN 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 informationWindows 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 informationCS 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 informationAPT 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 informationMemory 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 informationIntroduction 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 informationECE264 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 informationIntroduction 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 informationBIL 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 informationCS 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 informationChapter 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 informationCSE 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 informationCSci 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 informationProcedures, 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 informationCSCI-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 informationECEN 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 informationCS270 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 informationArrays, 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 informationIntroduction. 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 informationLab 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 informationToday 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 informationIntroduction 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 informationOutline. 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 informationIntroduction 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 informationCSC 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 information5) 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 informationProgramming 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 informationCSE 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 informationQ1: /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 informationScope: 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 informationTypes. 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 informationCS 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 informationCS61, 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 informationFORM 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 informationESC101N: 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 informationLab 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 informationECE 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 informationBuffer 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 informationReview: 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 informationStructured 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 informationCS201 - 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 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 information