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 trial

Java Java Objects Harnessing the Power of Objects Throwing Exceptions

Mike McKnight
Mike McKnight
6,717 Points

Throwing 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.

GoKart.java
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

Your 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
Brian Pedigo
26,783 Points

Hi 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;
    }
  }