Now a days many projects failed due to performance constraints and server load problems.
These tips and tricks will help many of us to solve performance related issues.
Programming Approach:
1. Avoid using static variables.
2. Avoid using Loops if possible.
3. User Additional variables to check states and validations for example:
In banking application, we want to fetch list of eligible candidates for loan then we break things into some parts
1. Fetching list of candidates for that loan.
2. Iterating them and finding their record for another loan application, checking in defaulter list.
3. Now for particular employee document verification check will be done.
4. If everything suffice then business rules will be applies to that list.
Here some general validations are
1. Employee's eligibility check
2. Checking in defaulter database.
3. Checking for document submission Yes/No.
4. Business Rules calculations.
By simply writing complex queries(applying joins) we can reduce all above 4 checks into flags like
isEligible, isDefaulter, isDocumentAvailable etc. when fetching results from query this can be used to operate accordingly.
In heavy list it is further useful to take advantage of mathematical calculations at query level. It helps in saving iteration and various flag values.
We can also check for multiple validations at one time by providing different validator objects including flags and relative checks.
4. Query Level Calculations: If records list is quite high, its better to calculate at query level rather then reiterating records to calculate values.
5. Using Language specific suggestion and tips and tricks:
Like we can use StringBuffer instead of String in java for strings subject to change. In some languages,using regular expression is quite heavy. avoiding equalsWithIgnoreCase to equals.
Minimize casting operations by taking variables according to their behavior i.e. float, int etc instead of String.
6. Properly utilizing tools like synchronization, serialization, bit arithmetic and replacing small conditions with conditional operations in place of switch case or condition statements hierarchy.
7. Using HashMaps for constant variables instead of declaring it as plain objects.
8. Separating error/exception handling throws from business rules, Its better to properly handing known exceptions to take actions rather then doing pre check.
e.g. In above mentioned banking example, We can make some checks for specific conditions that whether any employee false in that range or not. Whether employee information is valid or not. This exceptions can be thrown by your query and can be caught at exception handler unit. So its always better to reduce database load by properly utilizing exceptions.
9. Using Interfaces instead of Classes and using light weighted data types provided by language.
10. Minimize query load for properly utilizing connection pooling mechanism: Most critical reason of failing to performance constraint defined is query load, because it may affect with quantity of data. We can minimize queries load by writing complex queries, using function and procedures and performing query optimization and caching at different levels.
11. Light weighting exception related components: Sometimes its quite beneficial to use custom exceptions to work with different type of business rules, we can further optimize it and treat accordingly. Its good to use external mapping files(may be text,hashmap) for error messages and related information.
12. Programmer should not compromise at coding standards specially indenting, variable declaration and using simple functions instead of nested functions. Apart from it, it is always better to take dummy/temporary variables instead of recalling big objects again and again.
13. Optimizing member variable calculations: For any object, it is recommended that state variables should be modified according to data operations defined on that object.
For example: In maintaining account records in banking example mentioned above, that class should automatically vary different states like(total accounts, last indexes, account types etc) with incremental approach rather than calculating all things at one functional call.
Increment approach can be efficiently used at many other places also(like interface,DB to DB transfer etc).
14: Minimize load at synchronized junctions: It is better to do alternative checks(constraints, validations etc) before making any object entrance at synchronize state. It will help in filtering objects and reducing load at synchronized channel. Synchronized code should be optimal and efficient.
Remaining Tips will be updated soon..
Free Blog Service Network
Sunday, June 22, 2008
Performance Tuning
Posted by Free Blog Service at 4:18 AM 2 comments
Labels: improving code, performance tuning
Subscribe to:
Posts (Atom)