这行是你的问题:
litersOfPetrol = Float.parseFloat(df.format(litersOfPetrol));
在那里,您可以根据需要将浮点数格式化为字符串,但是随后该字符串再次转换为浮点数,然后在stdout中打印的内容是具有标准格式的浮点数。看一下这段代码
import java.text.DecimalFormat;
String stringLitersOfPetrol = "123.00";
System.out.println("string liters of petrol putting in preferences is "+stringLitersOfPetrol);
Float litersOfPetrol=Float.parseFloat(stringLitersOfPetrol);
DecimalFormat df = new DecimalFormat("0.00");
df.setMaximumFractionDigits(2);
stringLitersOfPetrol = df.format(litersOfPetrol);
System.out.println("liters of petrol before putting in editor : "+stringLitersOfPetrol);
顺便说一句,当您要使用小数时,请像其他人建议的那样忘记double和float的存在,而只使用BigDecimal对象,它将为您节省很多麻烦。