double freq; // (1)
try {
// here I get a DU anomaly
freq = Double.parseDouble(getFrequencyTextField().getText());
} catch (final NumberFormatException e) {
Log.e(e.getMessage());
freq = 0; // (2)
}
if (freq < 10E6) doSomething();
The first problem is that in the catch the parseDouble assignment is not done to freq.
On an exception freq still would be 0. Maybe flaggable.
So it goes away when assigning to freq inside catch.
When assigning to freq in the catch, (2), the inital assignment, (1), would never be read, so only a declaration suffices.
With respect to better style:
try {
// here I get a DU anomaly
double freq = Double.parseDouble(getFrequencyTextField().getText());
if (freq < 10E6) doSomething();
...
} catch (final NumberFormatException e) {
Log.e(e.getMessage());
}
Or follow the answer of @JoachimSauer, using a double conversion that does not throw an exception. The logging would indicate a level of seriousness in preference of the above style. Logging inside a simple conversion function on error might not be good style: too much logging, ignored logging (?), hard to repair.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…