Your program - you just provide the filling in the sandwich
Archive - Originally posted on "The Horse's Mouth" - 2011-04-08 23:34:28 - Graham Ellis You may think (and say) that you're writing a program ... but you never write a complete program these days.  What you do is to provide the filling to the sandwich - the bit that changes from one application / requirement to the next, and you then make use of standard surrounding material - the bread.
You may think (and say) that you're writing a program ... but you never write a complete program these days.  What you do is to provide the filling to the sandwich - the bit that changes from one application / requirement to the next, and you then make use of standard surrounding material - the bread.On top of your code sits the standard element provided by the language that you're using that loads your program into the multi-program operating system, ensures that you don't overlap with anyone else in terms of memory, disc files, screen real estate, network ports, etc ... and which then calls your main function - i.e. calls in the filling. In C and C++ (I was running a C and C++ coursei this week, hence the selection of this language for my example) this function is actually called "main" and will be where your own code is started from.
Your own code - the filling in the sandwich - provides the bit that's specilly written for your program. The bit that does what you program it to do, and not standard stuff that someone else has already written and shipped to you in standard units that everyone uses.
And below your code sit standard functions that you call to perform tasks that are common to a whole lot of programs - routines / code in named blocks from standard libraries. That's anything from "give me memory to store more data" through functions like calloc to "output this to the current standard output destination" through functions like printf.
Even a first "Hello World" program in C illustrates this eloquently:
  main() { /* Hook from above */
      printf("Greetings, Everyone\n"); /* Calling down below */
  }Of course, this first program is a most disappointing sandwich - it's mostly bread with only the tiniest trace of a filling. But it's the sort of code we write in the very first example of the course to show our delegates the environment in which their code sits and runs. We then expand that example a little - adding in comments to the code (very important for when you come back to look at what you wrote again later, or someone else does), a few more outputs, and perhaps calls to some of your own internal functions.
[link] - how to make a sandwich
The expanded example may be found [here] on our web site. It calls in other functions that we've written ourselves ... one of which is in the same file, and the other is in a separate file called shared.c - see [here]. The name "shared" should give you the clue that, as we expand, this is how we provide user written code that can be used in more than one application without duplicating the source code - and so without duplicating the work that has to be done in maintaining it.
Here, to complete this example, are the instructions I used on my (Unix / Mac OS X) system to compile and build the program. The same would work on Linux. On Windows, you can get gcc if you want, or you could use a different setup under which the same principle would be followed but in a different way.
munchkin:capr grahamellis$ gcc -c first.c
munchkin:capr grahamellis$ gcc -c shared.c
munchkin:capr grahamellis$ gcc -o first first.c shared.c
munchkin:capr grahamellis$ ./first
Issa MINE!  Mits orf!
Have a good day!
Have a good day!
Greetings from us
Time for a coffee!!
Have a good day!
Have a good day!
munchkin:capr grahamellis$* The first two instructions are compiling - preparing my ingredients - converting the Eglish-like source code into a sections of machine code
* The thild instructions joins all the components together into a single runnable file (and also puts them in the bread
* The fourth instruction actually runs the program ... and you'll see the results set out below it.
Every programming language has its own environment in which you enter code, prepare it to be run using standard code starting modules and library functions, and then ways of running it. And on all of our more basic courses, we'll cover this environment and how it works in one of the very early sessions. See [here] for our upcoming course schedule.
As I write, we're covering PHP next week, then Python and Tcl at the start of May on public courses. We're running private Ruby and Perl courses very soon too; the next Lua, C and C++ courses aren't for a couple of months. We've got all of the languages scheduled as public courses in the next four months ... and we're always open for bookings at least six months ahead. Why not come and learn with us? If you've never programmed before, you can find one of our courses which suits you (look for the courses named "learning to program in xxxx"). If you've programmed before, but in a different language to the one that you need to use now, book onto one of our courses described as "xxxx programming", and we'll convert you efficiently - making use of your existing knowledge of the principles of programming to get you writing good code in xxxx.