Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialMike McKnight
6,717 PointsThrowing Exception before change
It says I need to throw my exception before my change of lapsDriven. I attempted to put: int barsLeft = barCount -= laps; if (barsLeft<MIN_BARS); throw new IllegalArgumentException("Out of Fuel"); before it and it came up with a compiling error saying it was unreachable.
class GoKart {
public static final int MAX_BARS = 8;
public static final int MIN_BARS=1;
private String color;
private int barCount;
private int lapsDriven;
public GoKart(String color) {
this.color = color;
}
public String getColor() {
return color;
}
public void charge() {
barCount = MAX_BARS;
}
public boolean isBatteryEmpty() {
return barCount == 0;
}
public boolean isFullyCharged() {
return MAX_BARS == barCount;
}
public void drive() {
drive(1);
}
public void drive(int laps) {
lapsDriven += laps;
barCount -= laps;
int barsLeft = barCount -= laps;
if (barsLeft<MIN_BARS);
throw new IllegalArgumentException("Out of Fuel");
}
}
2 Answers
markmneimneh
14,132 PointsYour code will not work ....
this is a pseudo code to consider
lapsDriven += laps;
barCount -= laps;
if (barCount <MIN_BARS);
throw new IllegalArgumentException("Out of Fuel");
else
barsLeft = barCount - MIN_BARS ; // or whatever lower limit the challenge is setting
...
...
and so on
it been a long time since I too this particular challenge ... but please note the logic in the pseudo code
Brian Pedigo
26,783 PointsHi Mike it looks like you are updating your variables before you validating if they should be. First increment lapsDriven. Second set a check point (if statement) to see if the battery is empty, if the battery is empty throw the argument, otherwise lower the barCount by 1. I hope this helped!
public void drive(int laps) {
lapsDriven += laps;
if(isBatteryEmpty()){
throw new IllegalArgumentException;
} else {
barCount -= laps;
}
}