08
Wed, Jan
4 New Articles

Building a Better Programmer

General
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

What can an IT director do to increase programmers’ productivity? A lot. From providing a quiet workspace and state-of-the-art equipment to establishing commenting standards, here’s how to make good programmers even better.

In my 38-year career as a corporate programmer/analyst, I have seen thousands of programmers in action and worked with hundreds of IT directors. I’ve done my programming in marble-floored, wood-paneled headquarters and in grimy factories. I’ve used state-of-the-art equipment, and I’ve used “old iron.” I’ve been given a plush, private office, but I’ve also found myself crammed into a cubicle with another programmer in a room filled with yet dozens of other programmers. I’ve even found myself stationed by the copy machine. In all of these environments, one factor never varies: The speed and quality of my output always depends on the insight of the director of the IT department.

These 38 years of corporate programming have fostered some firm ideas about the kind of office environment that really works. I have found that some shops encourage programmers’ productivity while others seem bent on sabotaging it. With this in mind, I’ve created some guidelines that every IT manager should follow in order to create an environment in which employees can do their best work. Although most of these proposals may sound like common sense, heed them carefully. A shop that is managed too lightly may cripple good programmers while letting poor programming go undetected.

Demand the Best

Good equipment is the most important productivity enhancer an IT director can employ. That means fast hardware. This dictum may seem obvious, but in most of the IT departments I’ve seen, programmers must write their code using computers that make them wait far too long. What are they waiting for? Compiles! A programmer working on a slow AS/400 might be able to get 10 compiles a day—and have to wait half an hour to see the results of the compile. But with a state-of-the-art machine, a programmer might get 100 compiles a day and wait less than two minutes to see results. Insisting on state-of-the-art equipment will greatly affect your programmers’ productivity and the company’s bottom line.

Top-of-the-line equipment has another benefit as well. In today’s marketplace—in which disaffected programmers know they’ll get two or three job offers the day they leave a company — keeping your good staff members in a constant state of frustration hardly seems like a smart move. And compilation delays are infuriating for a serious programmer doing high-level work. So what can you do? I suggest that you devote more energy to persuading top management that your staff needs equipment with a response time of (effectively) 0.0 seconds. The elapsed time of source program compile, even for large programs, should be less than two minutes after the compile is submitted. Every source program compile should become active immediately and not languish on a job queue behind any other batch job.

All you really need to know about queuing theory is this: Your mission is to eliminate, or at least greatly reduce, all queues. Fast, current computer hardware can do this and can make you look like a productivity genius in the process. Providing state-of-the-art equipment will improve the productivity and the output quality of every programmer, at every level, by fundamentally changing the way your programmers approach, write, test, implement, and maintain programs and projects.

And a word of advice: Never give a programmer some old PC pulled out of a closet. Trust me, it will cost you dearly. At one of my client companies, for instance, I was given a PC that must have come out of the “to be repaired” closet. Although the company had called me in to do complex work and was paying me more than twice as much as it paid the IT department’s top programmer, I had to work with a computer that froze several times a day and was not fixed for weeks, costing my client thousands of dollars in lost programming t i m e . T h i s k i n d o f p e n n y - p i n c h i n g i s counterproductive—and commonplace. Need another example? Some of my clients (billion-dollar enterprises) still expect their programmers to work on 14-inch monitors. But focusing on a small screen is eyestraining, to say the least. Also, when a programmer with a 14-inch screen asks me to look over his shoulder and help untangle a coding knot, my response has to be, “Sorry, I can’t read your screen.”

All Quiet on the Work Front

If you can, provide each programmer with a 10-by-12 foot office. Think an office is not vital to your programmers’ productivity? Try swapping your office for a cubicle in the programmers’ bullpen for a month, and then watch your productivity plummet while the lucky programmer’s productivity soars. Although you can’t provide everyone with a plush corner office, you can establish a quiet environment in which your staffers can concentrate. All you need to do is lay down some rules.

In most of the offices where I’ve worked, no attention is paid to the noise level. Some programmers play radios in their cubicles. Some talk on speakerphones. Some banter with cubicle mates. Some wear headphones and code to the beat of the music pouring into their ears and into mine. And the rest of the programming staff, the serious workers, lose their concentration because they can’t get away from the noise.

Programming requires fierce focus. I find office noise so distracting that I routinely use a double wad of wax earplugs. Even so, programmers who are not working as hard or as quietly as they should be sabotage my concentration. IT directors need to pay attention to this serious, but solvable, problem.

Set up your department so that the workplace of every programmer is quiet. If staffers must be jammed together in cubicles, the office ground rules must be that they cannot play radios, use speakerphones, or talk with their colleagues in that cramped space. I find it best to have only one programmer in a cubicle and only one chair per programmer. That way discussion must be held in a private office. This may be against current custom, but it is hardly Draconian. It is simply the way a programming department should be set up.

Keep Your Eyes on the Prize

Hire the right people. Even in this tight employment market, you must hold out for programmers who, in their interviews, exhibit the traditional programming virtues: perseverance, flexibility, an interest in learning new languages or applications, and, most

important, a determination to understand the company’s business functions. Never hire a programmer who thinks that his job is just to be a coder.

Devise a Training Plan

Believe it or not, few of the programmers I’ve worked with over the years have had any sort of continuing professional coaching or training. That is why it is up to you, the IT director, to develop programming standards based on your experience with good programmers and consultants you have employed.

The most important thing to do is to set goals. Give all your programmers real direction. Provide a set of programming standards and techniques, guidelines on project documentation, and guidelines on how your IT department operates. Expect the procedures you set up to be followed from day one and have a project leader review every programmer’s work.

Here are some tips to help with this training: Have a “welcome to the department” package ready for every new consultant or new employee. Newcomers shouldn’t have to ask where the printer is or what their password is, but in the programming world, they routinely have to ask these kinds of questions. (See the sidebar “They’ve Gotta Have It: What Every Newly Hired Programmer Needs.”)

On the first day, have your new employee review the production source programs written by your best programmer and tell the new hire to use these programs as models. This shows your new employees that your company has standards and you expect them to write code that is heavily commented with explanations. I always use this technique when I mentor a programmer.

Establish a universal commenting style. As the IT manager, you have the responsibility to set a departmental “commenting style” that every programmer will use when writing source code. In many shops, each programmer writes in his own idiosyncratic way. The unfortunate consequence? When a programmer goes on to other projects, the code left behind is often a mystery to the programmers who come after.

Educate your programmers on your company’s business. You should provide a comprehensive facility or plant tour and have the new programmer observe other company personnel in the various divisions, such as accounts payable, warehousing, manufacturing, and distribution. Taking your new recruit on tour is important because these departments have business applications that the programmer will have to work on. Your programmers may know how to code, but they often don’t know much about business functions. Making sure your programmers learn these business applications is one of the most important things you can do.

The techniques you come up with should be the “basic training” you give your new recruit. Back in the early sixties when I became a programmer, IBM gave every systems engineer this kind of training. It works!

Real Results Real Soon

Hire programmers at full pay for a six-month trial period and give them your formal development plan. Gradually increase the difficulty of their projects. Then have a thorough and objective performance evaluation. If your new programmer meets your objectives, hire that programmer at a salary significantly above market pay.

Require every programmer to give you a one-page project activity summary every week and schedule a five-minute meeting to review it and set goals. Ask these questions every week: How are you doing? What can you or I do to make you more productive and happy? What are your concerns, your suggestions, and your ideas? Give direction and performance feedback and prioritize projects.

Also, you should provide separate test and production environments, and set up a formal change management system to relieve the programmer from operational responsibilities. Before a new or modified program goes into production, put it into “pilot production” by letting a single user (say, a packer in a distribution center) implement it in production under the watchful eye of the programmer who wrote or modified the code. If there’s a glitch in the program, it will crash for the pilot user, not for the entire company. And if it does crash, the pilot user in the production environment can give your programmer valuable feedback.

Provide to your programmers extensive and continuing technical and business application education. Require that all of your programmers take advantage of it. Some corporations refuse to give ongoing training because they really don’t want their employees to grow. Why? Because these very employees might go out and get better jobs! This attitude is both wrongheaded and expensive. Companies today must make a programmer’s job so attractive — through salary, bonuses, and opportunities to learn new techniques — that the programmer will want to stay. Simply put, good programmers are not interested in taking jobs at firms that do not give them a chance to grow. Besides, it is futile to hope that talented programmers will not eventually leave to become consultants. The best way to get extra work out of your programmers is to foster their growth. If you do so, your programmers will enrich your company’s code while they increase their skills.

You Say Goodbye, I Say Hello

Despite your best efforts, there will inevitably come a time when you lose your best programmers. Why? Because the best will always grow out of the environments that created them. However, by acquiring the best hardware and by training new recruits intelligently, you can minimize the pain of a good programmer’s departure. Meanwhile, if you, as an IT director, are wise enough to give your people the hardware and the guidance they need to succeed, they will steadily become the best programmers they can be. And you and your company will reap the rewards of better systems, higher quality applications, increased productivity, and happy, productive users.

They’ve Gotta Have It: What Every Newly Hired Programmer Needs

1. Private 10-by-12 foot office

2. Fully furnished office with one comfortable swivel chair

3. New PC with 17-inch monitor and loaded with all necessary software that also has a password and Internet access

4. Telephone with voicemail (no speakerphone)

5. Valid QPGMR user profile and sign-on for the AS/400 test environment

6. Office manuals including IT department mission statement, orientation information, office procedures, and programming standards documents

7. Key production source programs as a model for all programming

8. Tour of IT department and company facilities

9. Programmer orientation and training plan
10. Scheduled projects, coordinated with education and training and performance reviews
11. Introductory lunch with the programming manager and senior programmer mentor

BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  • SB Profound WC 5536 Have you been wondering about Node.js? Our free Node.js Webinar Series takes you from total beginner to creating a fully-functional IBM i Node.js business application. You can find Part 1 here. In Part 2 of our free Node.js Webinar Series, Brian May teaches you the different tooling options available for writing code, debugging, and using Git for version control. Brian will briefly discuss the different tools available, and demonstrate his preferred setup for Node development on IBM i or any platform. Attend this webinar to learn:

  • SB Profound WP 5539More than ever, there is a demand for IT to deliver innovation. Your IBM i has been an essential part of your business operations for years. However, your organization may struggle to maintain the current system and implement new projects. The thousands of customers we've worked with and surveyed state that expectations regarding the digital footprint and vision of the company are not aligned with the current IT environment.

  • SB HelpSystems ROBOT Generic IBM announced the E1080 servers using the latest Power10 processor in September 2021. The most powerful processor from IBM to date, Power10 is designed to handle the demands of doing business in today’s high-tech atmosphere, including running cloud applications, supporting big data, and managing AI workloads. But what does Power10 mean for your data center? In this recorded webinar, IBMers Dan Sundt and Dylan Boday join IBM Power Champion Tom Huntington for a discussion on why Power10 technology is the right strategic investment if you run IBM i, AIX, or Linux. In this action-packed hour, Tom will share trends from the IBM i and AIX user communities while Dan and Dylan dive into the tech specs for key hardware, including:

  • Magic MarkTRY the one package that solves all your document design and printing challenges on all your platforms. Produce bar code labels, electronic forms, ad hoc reports, and RFID tags – without programming! MarkMagic is the only document design and print solution that combines report writing, WYSIWYG label and forms design, and conditional printing in one integrated product. Make sure your data survives when catastrophe hits. Request your trial now!  Request Now.

  • SB HelpSystems ROBOT GenericForms of ransomware has been around for over 30 years, and with more and more organizations suffering attacks each year, it continues to endure. What has made ransomware such a durable threat and what is the best way to combat it? In order to prevent ransomware, organizations must first understand how it works.

  • SB HelpSystems ROBOT GenericIT security is a top priority for businesses around the world, but most IBM i pros don’t know where to begin—and most cybersecurity experts don’t know IBM i. In this session, Robin Tatam explores the business impact of lax IBM i security, the top vulnerabilities putting IBM i at risk, and the steps you can take to protect your organization. If you’re looking to avoid unexpected downtime or corrupted data, you don’t want to miss this session.

  • SB HelpSystems ROBOT GenericCan you trust all of your users all of the time? A typical end user receives 16 malicious emails each month, but only 17 percent of these phishing campaigns are reported to IT. Once an attack is underway, most organizations won’t discover the breach until six months later. A staggering amount of damage can occur in that time. Despite these risks, 93 percent of organizations are leaving their IBM i systems vulnerable to cybercrime. In this on-demand webinar, IBM i security experts Robin Tatam and Sandi Moore will reveal:

  • FORTRA Disaster protection is vital to every business. Yet, it often consists of patched together procedures that are prone to error. From automatic backups to data encryption to media management, Robot automates the routine (yet often complex) tasks of iSeries backup and recovery, saving you time and money and making the process safer and more reliable. Automate your backups with the Robot Backup and Recovery Solution. Key features include:

  • FORTRAManaging messages on your IBM i can be more than a full-time job if you have to do it manually. Messages need a response and resources must be monitored—often over multiple systems and across platforms. How can you be sure you won’t miss important system events? Automate your message center with the Robot Message Management Solution. Key features include:

  • FORTRAThe thought of printing, distributing, and storing iSeries reports manually may reduce you to tears. Paper and labor costs associated with report generation can spiral out of control. Mountains of paper threaten to swamp your files. Robot automates report bursting, distribution, bundling, and archiving, and offers secure, selective online report viewing. Manage your reports with the Robot Report Management Solution. Key features include:

  • FORTRAFor over 30 years, Robot has been a leader in systems management for IBM i. With batch job creation and scheduling at its core, the Robot Job Scheduling Solution reduces the opportunity for human error and helps you maintain service levels, automating even the biggest, most complex runbooks. Manage your job schedule with the Robot Job Scheduling Solution. Key features include:

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • LANSAWhen it comes to creating your business applications, there are hundreds of coding platforms and programming languages to choose from. These options range from very complex traditional programming languages to Low-Code platforms where sometimes no traditional coding experience is needed. Download our whitepaper, The Power of Writing Code in a Low-Code Solution, and:

  • LANSASupply Chain is becoming increasingly complex and unpredictable. From raw materials for manufacturing to food supply chains, the journey from source to production to delivery to consumers is marred with inefficiencies, manual processes, shortages, recalls, counterfeits, and scandals. In this webinar, we discuss how:

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • Profound Logic Have you been wondering about Node.js? Our free Node.js Webinar Series takes you from total beginner to creating a fully-functional IBM i Node.js business application.

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: