SlideShare a Scribd company logo
Software Development Best Practices
----
Coding Standards & Maintainable Code
Ankur Goyal
Email: ankur.fbd@gmail.com
for(j=0; j<array_len; j+ =8)
{
total += array[j+0 ];
total += array[j+1 ];
total += array[j+2 ]; /* Main body of
total += array[j+3]; * loop is unrolled
total += array[j+4]; * for greater speed.
total += array[j+5]; */
total += array[j+6 ];
total += array[j+7 ];
}
Warm up
for(j=0; j<array_len; j+ =8)
{
total += array[j+0 ];
total += array[j+1 ];
total += array[j+2 ];
/*
Main body of loop is unrolled for greater speed
total += array[j+3];
total += array[j+4];
total += array[j+5];
*/
total += array[j+6 ];
total += array[j+7 ];
}
Isn’t it better ?
What is it you expect, to get out of this Session?
Participant’s Expectations
Setting Expectations Right
• What this session is about?
– Identify & appreciate the importance of Coding
Standards
– Few examples
– Introduction to standard supporting tools
• What this session is not about?
– Coding Tutorial
– Details on coding standards
Maintainability
• Maintainability is the ease with which a product
can be modified in order to:
– correct defects or their cause
– meet new requirements
– cope with a changed environment
– e.g. iOS 5 to iOS 6, windows 7 to windows 8
Write simple, self-documenting code that is pleasant to revisit
even after months.
Coding Standards
• Coding standards are guidelines for code style
and documentation.
• The purpose is that any developer familiar with
the guidelines can work on any code that
followed them.
• We need to write code that minimizes the time it
would take someone else to understand it ---
even if that someone else is you.
Why Have Coding Standards?
• Reducing the cost of
software maintenance is the
most often cited reason for
following coding standards.
• ~80% of the lifetime cost of
a piece of software goes to
maintenance.
Is this really necessary ?
• YES. To all programmers, even if there is only one
developer on the project.
• Because:
– Most of the time software is not maintained by
the original author.
– If everyone follows the standards, you feel
comfortable using your colleague's code,
because it seems like your own code.
hmmm really ?
– Estimations are approved considering an average
programmer who follows coding standards.
– Not following coding standards will lead to review
comments & thereby rework, which in turn will lead to
effort variation.
– Since most of the time client delivery dates are fixed
hence it all leads to extra hours spent in office -> more
time -> more money.
– It’s a vicious circle, only way out is following coding
standards.
FEW
EXAMPLES
Using constants on LHS
• Constants should always be used on left hand
side of equality operator
• Avoids invalid assignment
• Avoids null pointer exceptions
Using constants on LHS
T h i s c o d e c a n c a u s e
N u l l P o i n t e r E x c e p t i o n
i f p a s s e d a r g u m e n t
‘ i n p u t ’ i s n u l l
R i g h t A p p r o a c h
Indentation
• Gives an indication of scope though doesn’t
affect program
• Must for maintainability & readability of code
Example
Compare
- Easier to Read
- Easier to Understand
- Easier to maintain
To
Pressing “Ctrl+shift+f” in eclipse formats source file
(set up your formatting style in Window|preferences | java | code style | formatter)
Commenting Code
• Document WHY & WHAT along with HOW.
• Comments should
- Clearly demonstrate the function of the code,
both to yourself and to other developers
• Comments should NOT be
- Too long
- Overcomplicated
Example
Compare
Example
To
 Comments are not about how much you write
 Comments should add illustration to the code for maintainability
Naming Variables
• Variable names are often thought to be less
important but they are vital to understanding
certain pieces of code.
• In the majority of programming languages,
variables can be assigned almost any name.
Example
Compare following:
To:
Trade off is generally between meaningfulness & shortness, rule of thumb is, always give
priority to meaningfulness.
Instance Creation
• Do not create instances as far as possible.
• creation of new instance is avoided in the
internal part of loop.
Example
Compare
Instance creation in loop, this may lead
to out of memory error…
To
Instance Creation
• Use valueOf() instead of new().
• valueOf() provides value from cache while
new() creates new instance.
Example
use
instead of
Cast
• As much as possible cast must be enclosed in
condition statement of instanceof.
Use instanceof()
This may lead to classcastexception
Use instanceof to avoid
classcastexception
Unreadable Code
• Write a code that can be understood by any
average programmer.
• This helps in maintainability & readability of
code.
• Helpful in understanding time critical projects
Example
Compare
To
Programmer’s expertise is not in writing complex code, expertise
is to write a code which is easy to understand & maintain.
String Concatenation
• Use StringBuffer and StringBuilder for String
concatenation operations.
• String is immutable hence creates new objects
whenever the value is changed
• Use StringBuffer if application is multithreaded &
synchronization is required
• Use StringBuilder elsewhere.
Example
Instead of
Use
Or
String object is
immutable whereas
StringBuffer/
StringBuilder
objects are mutable
REPOSITORY COMMENTS
• Often it is observed that repository comments do
not get the attention they deserve.
• Repository comments should convey the changes
committed along with applicable references e.g
– If bug is fixed mention fixed bug ID
– If any CR is implemented mention CR number/name
– If review comments are fixed mention review plan id
Example
Following are some of the real svn repo comments:
SVN repo comments serve purpose of maintaining code revision history, pay
respect to this fact & spend some time to write useful comments
Coding Standard & Best Practices
Tools
• CheckStyle
– makes sure that everyone in the team write code in a
similar manner
– is the glue that enables people to work together and to
free up their creativity instead of spending time and
energy at understanding inconsistent code.
• PMD
– reminds you of bad practices such as:
• Catching an exception without doing anything
• Suboptimal code - wasteful String/StringBuffer usage
• Duplicate code - copied/pasted code means copied/pasted bugs
Recap
• The purpose is that any developer familiar with the
guidelines can work on any code that followed them.
• Following coding standards saves both time and
money.
• Standardize early - the effort to bring your old work
into the standard will be too great otherwise.
• Document every time you violate a standard.
• Industry Standards > organizational standards >
project standards > no standards.
THANKS !!!
 Guidelines & practices mentioned in this slide were just a
tip of iceberg, there is no hard & fast rule regarding
guideline & they generally differ on basis of domain,
technology used & clients’ requirement etc.
Purpose of this presentation was to encourage habit of
following standards by identifying importance of the same.
Finally, following guidelines & adhering to standards is
responsibility of each individual.
Conclusion
Ad

Recommended

Coding standards
Coding standards
Mark Reynolds
 
Coding standards
Coding standards
Mimoh Ojha
 
Coding standards and guidelines
Coding standards and guidelines
brijraj_singh
 
Coding Best Practices
Coding Best Practices
mh_azad
 
Typescript ppt
Typescript ppt
akhilsreyas
 
Coding Standards & Best Practices for iOS/C#
Coding Standards & Best Practices for iOS/C#
Asim Rais Siddiqui
 
Selenium IDE LOCATORS
Selenium IDE LOCATORS
Mindfire Solutions
 
Clean code
Clean code
Jean Carlo Machado
 
Sonarqube
Sonarqube
Peerapat Asoktummarungsri
 
Code review
Code review
Abhishek Sur
 
Unit Testing in Swift
Unit Testing in Swift
GlobalLogic Ukraine
 
Clean Code I - Best Practices
Clean Code I - Best Practices
Theo Jungeblut
 
Selenium with java
Selenium with java
Gousalya Ramachandran
 
Static Code Analysis
Static Code Analysis
Annyce Davis
 
Test Driven Development (TDD)
Test Driven Development (TDD)
David Ehringer
 
Junit
Junit
FAROOK Samath
 
Angular Lifecycle Hooks
Angular Lifecycle Hooks
Squash Apps Pvt Ltd
 
C# coding standards, good programming principles & refactoring
C# coding standards, good programming principles & refactoring
Eyob Lube
 
Software testing
Software testing
Madhumita Chatterjee
 
Unit tests & TDD
Unit tests & TDD
Dror Helper
 
exception handling in java.ppt
exception handling in java.ppt
Varshini62
 
C# classes objects
C# classes objects
Dr.Neeraj Kumar Pandey
 
Clean code
Clean code
ifnu bima
 
UNIT TESTING PPT
UNIT TESTING PPT
suhasreddy1
 
Automation Testing Syllabus - Checklist
Automation Testing Syllabus - Checklist
Sunil Kumar Gunasekaran
 
Postman
Postman
Igor Shubovych
 
Coding standards for java
Coding standards for java
maheshm1206
 
Angularjs PPT
Angularjs PPT
Amit Baghel
 
CPP03 - Repetition
CPP03 - Repetition
Michael Heron
 
Design Like a Pro: Scripting Best Practices
Design Like a Pro: Scripting Best Practices
Inductive Automation
 

More Related Content

What's hot (20)

Sonarqube
Sonarqube
Peerapat Asoktummarungsri
 
Code review
Code review
Abhishek Sur
 
Unit Testing in Swift
Unit Testing in Swift
GlobalLogic Ukraine
 
Clean Code I - Best Practices
Clean Code I - Best Practices
Theo Jungeblut
 
Selenium with java
Selenium with java
Gousalya Ramachandran
 
Static Code Analysis
Static Code Analysis
Annyce Davis
 
Test Driven Development (TDD)
Test Driven Development (TDD)
David Ehringer
 
Junit
Junit
FAROOK Samath
 
Angular Lifecycle Hooks
Angular Lifecycle Hooks
Squash Apps Pvt Ltd
 
C# coding standards, good programming principles & refactoring
C# coding standards, good programming principles & refactoring
Eyob Lube
 
Software testing
Software testing
Madhumita Chatterjee
 
Unit tests & TDD
Unit tests & TDD
Dror Helper
 
exception handling in java.ppt
exception handling in java.ppt
Varshini62
 
C# classes objects
C# classes objects
Dr.Neeraj Kumar Pandey
 
Clean code
Clean code
ifnu bima
 
UNIT TESTING PPT
UNIT TESTING PPT
suhasreddy1
 
Automation Testing Syllabus - Checklist
Automation Testing Syllabus - Checklist
Sunil Kumar Gunasekaran
 
Postman
Postman
Igor Shubovych
 
Coding standards for java
Coding standards for java
maheshm1206
 
Angularjs PPT
Angularjs PPT
Amit Baghel
 

Similar to Software development best practices & coding guidelines (20)

CPP03 - Repetition
CPP03 - Repetition
Michael Heron
 
Design Like a Pro: Scripting Best Practices
Design Like a Pro: Scripting Best Practices
Inductive Automation
 
Design Like a Pro: Scripting Best Practices
Design Like a Pro: Scripting Best Practices
Inductive Automation
 
The View - Lotusscript coding best practices
The View - Lotusscript coding best practices
Bill Buchan
 
POLITEKNIK MALAYSIA
POLITEKNIK MALAYSIA
Aiman Hud
 
PHP Code Quality
PHP Code Quality
Usman Zafar
 
sCode optimization
sCode optimization
Satyamevjayte Haxor
 
Topic production code
Topic production code
Kavi Kumar
 
Software coding &amp; testing, software engineering
Software coding &amp; testing, software engineering
Rupesh Vaishnav
 
Cypress Best Pratices for Test Automation
Cypress Best Pratices for Test Automation
Knoldus Inc.
 
Putting Compilers to Work
Putting Compilers to Work
SingleStore
 
Test Drive Dirven Driver HAHAahhaha.pptx
Test Drive Dirven Driver HAHAahhaha.pptx
findwaytocom
 
代码大全(内训)
代码大全(内训)
Horky Chen
 
Autotools, Design Patterns and more
Autotools, Design Patterns and more
Vicente Bolea
 
Improving Code Quality Through Effective Review Process
Improving Code Quality Through Effective Review Process
Dr. Syed Hassan Amin
 
An Introduction To Software Development - Implementation
An Introduction To Software Development - Implementation
Blue Elephant Consulting
 
Introduction to C ++.pptx
Introduction to C ++.pptx
VAIBHAVKADAGANCHI
 
Dev buchan 30 proven tips
Dev buchan 30 proven tips
Bill Buchan
 
Indy meetup#7 effective unit-testing-mule
Indy meetup#7 effective unit-testing-mule
ikram_ahamed
 
[DevDay2018] Let’s all get along. Clean Code please! - By: Christophe K. Ngo,...
[DevDay2018] Let’s all get along. Clean Code please! - By: Christophe K. Ngo,...
DevDay Da Nang
 
Design Like a Pro: Scripting Best Practices
Design Like a Pro: Scripting Best Practices
Inductive Automation
 
Design Like a Pro: Scripting Best Practices
Design Like a Pro: Scripting Best Practices
Inductive Automation
 
The View - Lotusscript coding best practices
The View - Lotusscript coding best practices
Bill Buchan
 
POLITEKNIK MALAYSIA
POLITEKNIK MALAYSIA
Aiman Hud
 
PHP Code Quality
PHP Code Quality
Usman Zafar
 
Topic production code
Topic production code
Kavi Kumar
 
Software coding &amp; testing, software engineering
Software coding &amp; testing, software engineering
Rupesh Vaishnav
 
Cypress Best Pratices for Test Automation
Cypress Best Pratices for Test Automation
Knoldus Inc.
 
Putting Compilers to Work
Putting Compilers to Work
SingleStore
 
Test Drive Dirven Driver HAHAahhaha.pptx
Test Drive Dirven Driver HAHAahhaha.pptx
findwaytocom
 
代码大全(内训)
代码大全(内训)
Horky Chen
 
Autotools, Design Patterns and more
Autotools, Design Patterns and more
Vicente Bolea
 
Improving Code Quality Through Effective Review Process
Improving Code Quality Through Effective Review Process
Dr. Syed Hassan Amin
 
An Introduction To Software Development - Implementation
An Introduction To Software Development - Implementation
Blue Elephant Consulting
 
Dev buchan 30 proven tips
Dev buchan 30 proven tips
Bill Buchan
 
Indy meetup#7 effective unit-testing-mule
Indy meetup#7 effective unit-testing-mule
ikram_ahamed
 
[DevDay2018] Let’s all get along. Clean Code please! - By: Christophe K. Ngo,...
[DevDay2018] Let’s all get along. Clean Code please! - By: Christophe K. Ngo,...
DevDay Da Nang
 
Ad

Recently uploaded (20)

Best MLM Compensation Plans for Network Marketing Success in 2025
Best MLM Compensation Plans for Network Marketing Success in 2025
LETSCMS Pvt. Ltd.
 
Sysinfo OST to PST Converter Infographic
Sysinfo OST to PST Converter Infographic
SysInfo Tools
 
Simplify Insurance Regulations with Compliance Management Software
Simplify Insurance Regulations with Compliance Management Software
Insurance Tech Services
 
Azure AI Foundry: The AI app and agent factory
Azure AI Foundry: The AI app and agent factory
Maxim Salnikov
 
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
dheeodoo
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Heat Treatment Process Automation in India
Heat Treatment Process Automation in India
Reckers Mechatronics
 
Automated Testing and Safety Analysis of Deep Neural Networks
Automated Testing and Safety Analysis of Deep Neural Networks
Lionel Briand
 
Streamlining CI/CD with FME Flow: A Practical Guide
Streamlining CI/CD with FME Flow: A Practical Guide
Safe Software
 
How Automation in Claims Handling Streamlined Operations
How Automation in Claims Handling Streamlined Operations
Insurance Tech Services
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 
Digital Transformation: Automating the Placement of Medical Interns
Digital Transformation: Automating the Placement of Medical Interns
Safe Software
 
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
BradBedford3
 
Decipher SEO Solutions for your startup needs.
Decipher SEO Solutions for your startup needs.
mathai2
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
From Code to Commerce, a Backend Java Developer's Galactic Journey into Ecomm...
From Code to Commerce, a Backend Java Developer's Galactic Journey into Ecomm...
Jamie Coleman
 
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
2nd Sight Lab
 
Building Geospatial Data Warehouse for GIS by GIS with FME
Building Geospatial Data Warehouse for GIS by GIS with FME
Safe Software
 
HYBRIDIZATION OF ALKANES AND ALKENES ...
HYBRIDIZATION OF ALKANES AND ALKENES ...
karishmaduhijod1
 
Best MLM Compensation Plans for Network Marketing Success in 2025
Best MLM Compensation Plans for Network Marketing Success in 2025
LETSCMS Pvt. Ltd.
 
Sysinfo OST to PST Converter Infographic
Sysinfo OST to PST Converter Infographic
SysInfo Tools
 
Simplify Insurance Regulations with Compliance Management Software
Simplify Insurance Regulations with Compliance Management Software
Insurance Tech Services
 
Azure AI Foundry: The AI app and agent factory
Azure AI Foundry: The AI app and agent factory
Maxim Salnikov
 
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
ERP Systems in the UAE: Driving Business Transformation with Smart Solutions
dheeodoo
 
Microsoft-365-Administrator-s-Guide1.pdf
Microsoft-365-Administrator-s-Guide1.pdf
mazharatknl
 
Heat Treatment Process Automation in India
Heat Treatment Process Automation in India
Reckers Mechatronics
 
Automated Testing and Safety Analysis of Deep Neural Networks
Automated Testing and Safety Analysis of Deep Neural Networks
Lionel Briand
 
Streamlining CI/CD with FME Flow: A Practical Guide
Streamlining CI/CD with FME Flow: A Practical Guide
Safe Software
 
How Automation in Claims Handling Streamlined Operations
How Automation in Claims Handling Streamlined Operations
Insurance Tech Services
 
Zoho Creator Solution for EI by Elsner Technologies.docx
Zoho Creator Solution for EI by Elsner Technologies.docx
Elsner Technologies Pvt. Ltd.
 
Digital Transformation: Automating the Placement of Medical Interns
Digital Transformation: Automating the Placement of Medical Interns
Safe Software
 
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
Foundations of Marketo Engage - Programs, Campaigns & Beyond - June 2025
BradBedford3
 
Decipher SEO Solutions for your startup needs.
Decipher SEO Solutions for your startup needs.
mathai2
 
Canva Pro Crack Free Download 2025-FREE LATEST
Canva Pro Crack Free Download 2025-FREE LATEST
grete1122g
 
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
Modern Platform Engineering with Choreo - The AI-Native Internal Developer Pl...
WSO2
 
From Code to Commerce, a Backend Java Developer's Galactic Journey into Ecomm...
From Code to Commerce, a Backend Java Developer's Galactic Journey into Ecomm...
Jamie Coleman
 
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
Threat Modeling a Batch Job Framework - Teri Radichel - AWS re:Inforce 2025
2nd Sight Lab
 
Building Geospatial Data Warehouse for GIS by GIS with FME
Building Geospatial Data Warehouse for GIS by GIS with FME
Safe Software
 
HYBRIDIZATION OF ALKANES AND ALKENES ...
HYBRIDIZATION OF ALKANES AND ALKENES ...
karishmaduhijod1
 
Ad

Software development best practices & coding guidelines

  • 1. Software Development Best Practices ---- Coding Standards & Maintainable Code Ankur Goyal Email: [email protected]
  • 2. for(j=0; j<array_len; j+ =8) { total += array[j+0 ]; total += array[j+1 ]; total += array[j+2 ]; /* Main body of total += array[j+3]; * loop is unrolled total += array[j+4]; * for greater speed. total += array[j+5]; */ total += array[j+6 ]; total += array[j+7 ]; } Warm up
  • 3. for(j=0; j<array_len; j+ =8) { total += array[j+0 ]; total += array[j+1 ]; total += array[j+2 ]; /* Main body of loop is unrolled for greater speed total += array[j+3]; total += array[j+4]; total += array[j+5]; */ total += array[j+6 ]; total += array[j+7 ]; } Isn’t it better ?
  • 4. What is it you expect, to get out of this Session? Participant’s Expectations
  • 5. Setting Expectations Right • What this session is about? – Identify & appreciate the importance of Coding Standards – Few examples – Introduction to standard supporting tools • What this session is not about? – Coding Tutorial – Details on coding standards
  • 6. Maintainability • Maintainability is the ease with which a product can be modified in order to: – correct defects or their cause – meet new requirements – cope with a changed environment – e.g. iOS 5 to iOS 6, windows 7 to windows 8 Write simple, self-documenting code that is pleasant to revisit even after months.
  • 7. Coding Standards • Coding standards are guidelines for code style and documentation. • The purpose is that any developer familiar with the guidelines can work on any code that followed them. • We need to write code that minimizes the time it would take someone else to understand it --- even if that someone else is you.
  • 8. Why Have Coding Standards? • Reducing the cost of software maintenance is the most often cited reason for following coding standards. • ~80% of the lifetime cost of a piece of software goes to maintenance.
  • 9. Is this really necessary ? • YES. To all programmers, even if there is only one developer on the project. • Because: – Most of the time software is not maintained by the original author. – If everyone follows the standards, you feel comfortable using your colleague's code, because it seems like your own code.
  • 10. hmmm really ? – Estimations are approved considering an average programmer who follows coding standards. – Not following coding standards will lead to review comments & thereby rework, which in turn will lead to effort variation. – Since most of the time client delivery dates are fixed hence it all leads to extra hours spent in office -> more time -> more money. – It’s a vicious circle, only way out is following coding standards.
  • 12. Using constants on LHS • Constants should always be used on left hand side of equality operator • Avoids invalid assignment • Avoids null pointer exceptions
  • 13. Using constants on LHS T h i s c o d e c a n c a u s e N u l l P o i n t e r E x c e p t i o n i f p a s s e d a r g u m e n t ‘ i n p u t ’ i s n u l l R i g h t A p p r o a c h
  • 14. Indentation • Gives an indication of scope though doesn’t affect program • Must for maintainability & readability of code
  • 15. Example Compare - Easier to Read - Easier to Understand - Easier to maintain To Pressing “Ctrl+shift+f” in eclipse formats source file (set up your formatting style in Window|preferences | java | code style | formatter)
  • 16. Commenting Code • Document WHY & WHAT along with HOW. • Comments should - Clearly demonstrate the function of the code, both to yourself and to other developers • Comments should NOT be - Too long - Overcomplicated
  • 18. Example To  Comments are not about how much you write  Comments should add illustration to the code for maintainability
  • 19. Naming Variables • Variable names are often thought to be less important but they are vital to understanding certain pieces of code. • In the majority of programming languages, variables can be assigned almost any name.
  • 20. Example Compare following: To: Trade off is generally between meaningfulness & shortness, rule of thumb is, always give priority to meaningfulness.
  • 21. Instance Creation • Do not create instances as far as possible. • creation of new instance is avoided in the internal part of loop.
  • 22. Example Compare Instance creation in loop, this may lead to out of memory error… To
  • 23. Instance Creation • Use valueOf() instead of new(). • valueOf() provides value from cache while new() creates new instance.
  • 25. Cast • As much as possible cast must be enclosed in condition statement of instanceof. Use instanceof() This may lead to classcastexception Use instanceof to avoid classcastexception
  • 26. Unreadable Code • Write a code that can be understood by any average programmer. • This helps in maintainability & readability of code. • Helpful in understanding time critical projects
  • 27. Example Compare To Programmer’s expertise is not in writing complex code, expertise is to write a code which is easy to understand & maintain.
  • 28. String Concatenation • Use StringBuffer and StringBuilder for String concatenation operations. • String is immutable hence creates new objects whenever the value is changed • Use StringBuffer if application is multithreaded & synchronization is required • Use StringBuilder elsewhere.
  • 29. Example Instead of Use Or String object is immutable whereas StringBuffer/ StringBuilder objects are mutable
  • 30. REPOSITORY COMMENTS • Often it is observed that repository comments do not get the attention they deserve. • Repository comments should convey the changes committed along with applicable references e.g – If bug is fixed mention fixed bug ID – If any CR is implemented mention CR number/name – If review comments are fixed mention review plan id
  • 31. Example Following are some of the real svn repo comments: SVN repo comments serve purpose of maintaining code revision history, pay respect to this fact & spend some time to write useful comments
  • 32. Coding Standard & Best Practices Tools • CheckStyle – makes sure that everyone in the team write code in a similar manner – is the glue that enables people to work together and to free up their creativity instead of spending time and energy at understanding inconsistent code. • PMD – reminds you of bad practices such as: • Catching an exception without doing anything • Suboptimal code - wasteful String/StringBuffer usage • Duplicate code - copied/pasted code means copied/pasted bugs
  • 33. Recap • The purpose is that any developer familiar with the guidelines can work on any code that followed them. • Following coding standards saves both time and money. • Standardize early - the effort to bring your old work into the standard will be too great otherwise. • Document every time you violate a standard. • Industry Standards > organizational standards > project standards > no standards.
  • 34. THANKS !!!  Guidelines & practices mentioned in this slide were just a tip of iceberg, there is no hard & fast rule regarding guideline & they generally differ on basis of domain, technology used & clients’ requirement etc. Purpose of this presentation was to encourage habit of following standards by identifying importance of the same. Finally, following guidelines & adhering to standards is responsibility of each individual. Conclusion