LOG kills
Never activates log in DEBUG mode. That kills memory and performance. Always use INFO. Debug should be used with AOP to trace execution only.
This blog is about all stupid line of codes wrote by java developers.
Never activates log in DEBUG mode. That kills memory and performance. Always use INFO. Debug should be used with AOP to trace execution only.
Posted by
amertum
at
23:06
0
comments
Labels: log, memory, performance
Money
int value;
String currency;
Money add(Money initial, Money toAdd) {
int value = initial.getValue() + dogAmount.getValue();
Money money = new AnimalMoney(value, initial.getCurrency())
return money;
}
Money cat = new AnimalMoney(5, "cat");
Money dog = new AnimalMoney(1, "dog");
Money deal = add(cat, dog);
Posted by
amertum
at
22:15
0
comments
Labels: bug, code style, type
How appears a vicious OutOfMemoryError on 2/3 of the dev computer ?
The same JVM, the same sources, the same web server...
Everything is the same ! Everything ? Not the application config file nor the log4j config file.
Yep, OutOfMemory because of DEBUG level, others with INFO. Why ? Because of the fuck root handler the gives the DEBUG level for every API that use log4j, and so for the one that log the application database access. More than 1GB while we use only 300MB ordinary.
Becareful with logger. Always use root INFO and provides category for your application packages.
Posted by
amertum
at
01:50
0
comments
Labels: bug, log, OutOfMemoryError
Book myBook = getBookFromSomeWhere();
System.out.println("myBook: " + myBook);
if (myBook == null) {
System.out.println("myBook is null");
}
else {
System.out.println("myBook is not null");
}
myBook: null
myBook is not null
Book {
...
public String toString() {
return "null";
}
Posted by
amertum
at
18:33
0
comments
Basically the implementation look like :
if client => send email to client
if enterprise => send email to client
if others => send email to client
BUT this behavior was not as specified. It should be :
if client => send NO email
if enterprise => send email to enterprise
if others => send email to enterprise
And guess what, it was in production because of ME. Yes, ME. I'm gonna kill myself. How it could be, how I could make such a mistake. By focusing too much on code aspect.
This teach me a great thing. Of course the code aspect, the architecture and so on are important, but the business target IS MORE IMPORTANT than every thing.
Today, I was the stupid guy because Errare Humanum Est.
Posted by
amertum
at
16:15
0
comments
// defined previously
// Date aDate = ...
Date date = new Date();
date = new Date(date.getTime());
if (aDate != null && aDate == date) {
date = new Date(date.getTime() + 10);
}
Date date = new Date();is stupid.
date = new Date(date.getTime());
Date date = new Date();is sufficient.
Posted by
amertum
at
14:13
0
comments
public static int roundSup(float n){
int round=0;
if(n > (new Float(n).intValue()))
round = new Float(n+1).intValue();
else round=new Float(n).intValue();
return round;
}
public static int roundSup(
final float n
) {
return ((int) n) + 1;
}
Posted by
amertum
at
15:52
0
comments