For 2023 - we are now fully retired from IT training.
We have made many, many friends over 25 years of teaching about Python, Tcl, Perl, PHP, Lua, Java, C and C++ - and MySQL, Linux and Solaris/SunOS too. Our training notes are now very much out of date, but due to upward compatability most of our examples remain operational and even relevant ad you are welcome to make us if them "as seen" and at your own risk.
Lisa and I (Graham) now live in what was our training centre in Melksham - happy to meet with former delegates here - but do check ahead before coming round. We are far from inactive - rather, enjoying the times that we are retired but still healthy enough in mind and body to be active!
I am also active in many other area and still look after a lot of web sites - you can find an index ((here))
Do languages change?
How fast do computer languages change
? Not as quickly as you might expect - and yet we're regularly updating our courses. This is because the underlying bedrock (languages) don't change very much, but the functions / libraries / classes / technologies that use them do change, and the applications that use the libraries and technologies change even faster. Many of the examples from the first Perl course
that I taught will still work, but the style is dated and there are better ways and technologies. In those days, XML and XSLT
were unheard of, MySQL
was very new and a specialist interest, and the Web was in its infancy.
I was talking about this yesterday, and drew this parallel ...
A programming language is like a railway track. It's specified and laid out and survives broadly unaltered over hundreds of years. Small improvements in alignment and quality are made and there's considerable strengthening for progressing requirements, but basically it's still the same track.
Functions / libraries / classes / technologies are rather like the trains that run on the tracks. Trains have a lifespan of perhaps 25 to 40 years - they have teething troubles in the early days ("the wrong sort of snow") but then give many years of sterling service, to be replaced with new at the end of their life cycle. You can see a good example of how this happened in programming terms with libraries such as the Java Utility classes
where the Java 1.0 classes were largely deprecated in favour of new libraries prior to the release of Java2.
Finally, applications are more transient again - they change rather like the fittings and fixtures in the train. Travelling on (the same) trains over the past 20 years, I've seen second class become standard class, the addition of hammers to break the windows to escape in an emergency, the advent of quiet carriages and a family carriage and more. (written 2004-09-08, updated 2008-05-10)
Associated topics are indexed as below, or enter http://melksh.am/nnnn for individual articlesJ714 - Java - Fundamental classes 
Java sorting - comparable v comparator - (2007-02-02) 
Java, sorting, ArrayList example, generics - (2008-01-11) 
Java - Generics - (2008-11-27) 
Java Collection Objects in the java.util package - (2009-08-05) 
Viv.java uses unchecked or unsafe operations - explanation and cure - (2009-09-24) 
Sorting Collections of Objects in Java - (2009-09-25) 
Length, size or capacity in Java? - (2010-02-24) 
for and foreach in Java - (2010-04-22) 
Sorting - naturally, or into a different order - (2010-08-14) 
String handling - from first steps to practical examples - (2010-11-13) 
Java - factory method, encapsulation, hashmap example - (2014-11-27) 
Java Utility class - flexible replacement for array. Also cacheing in objects and multiple catch clauses example. - (2015-01-16) 
How healthy are the stars of stage and screen? - (2015-02-09) 
A Java servlet that is also a stand alone program. And a server that is also a web client. - (2015-02-19)
Some other Articles
Near and far securityCGI v mod_perlSerious subjectHash of lists in PerlDo languages change?A Thousand and four wordsTake the train to trainingA Change is as good as a restAn update for old friendsSecurity and Safety
4759 posts, page by page
Link to page ... 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96 at 50 posts per page
This is a page archived from The Horse's Mouth at
the diary and writings of Graham Ellis.
Every attempt was made to provide current information at the time the
page was written, but things do move forward in our business - new software
releases, price changes, new techniques. Please check back via
our main site for current courses,
prices, versions, etc - any mention of a price in "The Horse's Mouth"
cannot be taken as an offer to supply at that price.
Link to Ezine home page (for reading).
Link to Blogging home page (to add comments).