Do you want to get hold of your
coding style and become the Zen of coding with less effort; the best place to
go is to buy the book “Code Complete by
Steve McConnell”. He teaches in a way that even layman can get it. After reading,
I thought let me write the best he got in this book. I have carefully selected
only the simple tips/tricks and techniques, which may be things you have
already used in your project. But still it is good to revise.
He goes through the
book with the map of software life cycle from designing software to code tuning
them.
In First few chapters he talks about
stakeholders, STAKEHOLDERS are everyone who uses the software, starting from
developer\QA\Project managers to actual end users and how to manage each stakeholder’s
requirement through your requirement document.
Let’s start
with system architecture where we will concentrate more on how system
architecture and what constitutes a good architecture.
What is System Architecture?
It is the
overview about the system which must address all the requirement of
stakeholders with views and perspectives.
I have carefully chosen only important details that SHOULD
be handled while creating the Technical design document which was explained by
the author. I have left some of the known details that constitute the Technical
document.
Details that needs to be covered in the
technical documents are
Alternatives
Alternatives
of the current solution, why the system did not choose the alternatives and
also the justification for the alternative
Major modules
Major
modules should be identified and should also be defined in the system,
Identifying them is the key.
Change Strategy
System
should be designed to handle changes early. For e.g. changing requirement
should be configurable.
Buy vs. Build Decision
Deciding
which module or the part of project should be developed by the development team
or the software should be bought from third party vendor. If the project has an
office document report that needs to be created, going for Microsoft DLL to
create the report is not a good option, because Microsoft do not support office
installed in server, so you have to buy any third party vendor software for
office report utilities, I recommend ASPOSE.
Major Data Structure.
Data structure chosen must be
explained over another. E.g. choosing IList as parameter over dataset is the
best option because IList is lighter than dataset.
Key Algorithms
All key
algorithms should be explained clearly. For example, if the module has a functionality
which includes tax calculation and we use tax calculation with flexi benefits
then those algorithms should be explained in detail. You also have to decide
whether we can use any software or service that is available already in market.
Deciding critical factor to identify
major objects
·
Responsibility of the object
·
How it is implemented
·
How objects interact with other objects
·
Description of Class hierarchies
·
State Transition and persistence
Memory Management
Memory used
for nominal and extreme cases. Requirement should be collected from the
stakeholders. eg.., What might be the maximum number of users that will use the
application and what are the frequently visited pages or application. Rough
level of calculation must be done to test the results after development.
String Storage
This seems
to be trivial, how string will be manipulated and stored has to be decided and
chosen as per the requirement of the project, because it saves lots of time.
E.g. whether error message should stored in a config file or a resource file,
if it is multilingual project.
Error Processing
In any code
written throughout ages, error processing is very important, the author gives
example that only 10% is written for nominal case and other 90% is for error
processing, so error processing strategy should be identified. Most important
is the error detection, whether it is active or passive detection meaning, will
the error be communicated to the user and action will be taken or the error
just logged.
Performance
Architect
should provide and estimate the performance for major module and get it
accepted by stakeholders, because business stakeholder really don’t care how
much time the batch job takes to runs at night for data replication, but they CARE
about the page load time.
Real time challenges in identifying the
modules.
Below are the list of areas you should concentrate on your requirement to identify modules.
Below are the list of areas you should concentrate on your requirement to identify modules.
Areas where changes are likely
·
Hardware Dependency
·
All complex Data\logic are likely to
change
·
Business Rules
Areas to concentrate while coding
·
Places likely to change
·
Complex Data
·
Complex logic
Good reasons to abstract to a new
Module
·
UI
·
Hardware dependency
·
System Management
·
I/O
Things
that I actively avoided in the article are below because I felt these are very
primal knowledge and too basic for a programmer
·
Conditional Statement
·
Using Break & Continue Statement
·
Using Loop
Variables
·
Recursion
·
Boolean expression
Let us see how the coding tuning should be done with
principles in mind.
Guidelines of Initializing Data
Initialize data as you declare it. Always take advantage of your compiler warning
General issues in using variables
Minimize the scope of the variable. Keep reference to variable together. Develop the habit of writing code assuming data isn’t persistent.
Statement whose orders don’t
matter
Principle
of paradox
Keep
related action together. Make code readable from top to bottom. Localize
reference to variable, never scatter variables. Keep variable life as short as
possible.
Controlling loops
Any loops
should have only one entry, author also recommends one exit but after reading
Martin Fowler books I feel whenever you don’t have any more operation that
needs to be done inside the loop, you can use return or break statement to come
out of the loop. Read about Guard statements, if you want to know more on this choice.
Choose while loop instead of for loop wherever possible. Avoid empty loops,
keep house keeping variable either at start or end of the loop.
Taming Dangerous Deep Nesting
Convert a
nested if to SET of if then else.
Factor deeply nested code into it’s routine. Redesign deeply nested code. Limit
the nesting to three levels in for loop
Document Code
Comment as
you go along. Always document on why
rather than how. Avoid abbreviation in comments
Encouraging Good Coding practises
Tips and Techniques
·
Assign two people for every part of the
project.
·
Review every line of code.
·
Require code sign off
·
Routing good code for review
Techniques for improving software
qualities
·
Define Software Quality objectives
·
Explicitly define quality assurance activities
·
Find the testing strategy earlier
during design
·
Figure out software guidelines, may be
very minimal, but it is better than none.
Methods to find error while Debugging
·
Be suspicious of routine that have had
error before
·
Check the code that recently changed
·
Expand the suspicious region
·
Integrate incrementally
·
Set maximum time for quick and dirty
debugging. This point fascinates me, author talks about setting a time limit
say 15 minutes for a dirty debugging, this he calls as gut level debugging, where
we figured out the place in our mind, where the bug might be without even
debugging the code sequentially.
·
Take break from the problem.
Advanced Code Tuning Techniques
Switching
My favourite
one is removing the decision, if they are not changing the condition of the
loop. I.e. removing the statement from inside the loop and placing it outside
if they are not changing the condition of the loop
Jamming
Combine
two loops that operate on the same set of elements
Sentinel Values
Value that
you put just past the end of search range and this guarantee to terminate the
search. There should be condition that should be validated and it should break
the control out of the loop
Busiest loop
Pull the
busiest loop to the inside. When you do this for any FOR loop operation which
is more than one level deep, you will reduce the number of times the loop is
executed.
Caching
Use caching
wherever possible, when you know data won’t change for a period of time or
never changes then use caching.
Use strength reduction
·
Replace (+) with (*)
·
Replace long with short
·
Initialize at compile time
I have compiled only the simple guidelines, tips and tricks,
so it is useful to everyone, if you want in depth knowledge then subscribe this
book from library. It is very useful book; it has tons and tons of idea
which will surely make you Zen in coding and helps you to figure out your own style.
Check out the book @ CodeComplete by McConnell
IMPORTANT: Leave a comment to share what you learnt, and hit the “like” button to let others know about it (make sure you’re logged into Facebook to like and comment).
Check out the book @ CodeComplete by McConnell
IMPORTANT: Leave a comment to share what you learnt, and hit the “like” button to let others know about it (make sure you’re logged into Facebook to like and comment).