15

The function below gets two values from sharedpreferences, weight and height, and I use these to calculate the BMI, When I print the content of the values I get the values i have entered in the sharedprefs ( which is good) but then when i run a division operation on them, I always get 0 as a result.. Where is the error?

public int computeBMI(){
    SharedPreferences customSharedPreference = getSharedPreferences(
            "myCustomSharedPrefs", Activity.MODE_PRIVATE);

    String Height = customSharedPreference.getString("heightpref", "");
    String Weight = customSharedPreference.getString("weightpref", "");

    int weight = Integer.parseInt(Weight);
    int height = Integer.parseInt(Height);
    Toast.makeText(CalculationsActivity.this, Height+" "+ Weight , Toast.LENGTH_LONG).show();

    int bmi = weight/(height*height);
    return bmi;

}
callback
  • 3,144
  • 1
  • 23
  • 47

3 Answers3

49

You're doing integer division.

You need to cast one operand to double.

SLaks
  • 800,742
  • 167
  • 1,811
  • 1,896
20

You are doing an integer division, cast the values to float and change the datatype of the variable bmi to float.

Like this:

float bmi = (float)weight/(float)(height*height);

You should also change the return type of your method public int computeBMI() to float.

I recommend you to read this stackoverflow question.

Here you have a list of the Primitive Data Types in Java with its full description.

Hope it helps!

Community
  • 1
  • 1
Cacho Santa
  • 6,444
  • 5
  • 36
  • 66
1

Because bmi is an integer. Either declare bmi or Weight, Height as floating point numbers. When you use integers in a division, you will get integer division. When you use doubles/floats, you will get floating point division

Piyush Mattoo
  • 14,524
  • 6
  • 49
  • 58