陷入while循环/索引越界异常

时间:2013-08-09 14:41:01

标签: java android while-loop sensor

我想弄清楚步骤何时发生。所以我编写了一个名为countSteps的方法来执行此操作。它的问题是我陷入其中,因为使用while循环我不断获得新数据,我不认为它会返回onSensor。我还得到一个名为indexoutofboundsexception的错误:索引2无效,大小为2。

所以我的第一个问题是有没有其他方法来实现我没有while循环的方法?其次是我如何修复indexoutofboundsexception。  公共类MainActivity extends Activity实现SensorEventListener {

    private SensorManager mSensorManager;
    private Sensor mRotationVector;
    private Sensor mAccelerometer;
    private TextView mTextView4;
    private TextView mTextView5;
    private TextView mTextView6;
    private TextView mTextView7;
    private TextView mTextView8;
    float a, b, c, d, x, y, z, xyz;
    float[] retVals = new float[3];
    float avg = 10;
    float factor = (float) 1.15;
    ArrayList<Float> accelData = new ArrayList<Float>();
    public int peakCounter = 0;
    public int underAvgCounter = 0;

    public void countSteps() {
        int n = 0;
        float controlPoint = accelData.get(0);
        while (accelData.iterator().hasNext()) {
            if (accelData.get(n) != accelData.get(n + 1)) {
                if (accelData.get(n) > accelData.get(n + 1)) {
                    if (accelData.get(n) < controlPoint) {
                        n++;
                    } else {
                        if (accelData.get(n) < avg * factor) {
                            underAvgCounter++;
                        }
                        peakCounter++;
                        n++;
                    }
                } else {
                    controlPoint = accelData.get(n + 1);
                    n++;
                }
            } else {
                n++;
            }
            peakCounter -= underAvgCounter;
        }
    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView4 = (TextView) findViewById(R.id.textView4);
        mTextView5 = (TextView) findViewById(R.id.textView5);
        mTextView6 = (TextView) findViewById(R.id.textView6);
        mTextView7 = (TextView) findViewById(R.id.textView7);
        mTextView8 = (TextView) findViewById(R.id.textView8);
        mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
        mAccelerometer = mSensorManager
                .getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        accelData.add((float) 0);
    }

    protected void onResume() {
        super.onResume();
        mSensorManager.registerListener(this, mAccelerometer,
                SensorManager.SENSOR_DELAY_GAME);
    }

    protected void onPause() {
        super.onPause();
        mSensorManager.unregisterListener(this);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public void onAccuracyChanged(Sensor sensor, int accuracy) {
        // TODO Auto-generated method stub

    }

    @Override
    public void onSensorChanged(SensorEvent event) {
            x = event.values[0];
            y = event.values[1];
            z = event.values[2];
            xyz = (float) Math.sqrt((x * x) + (y * y) + (z * z));
            accelData.add(xyz);
            mTextView7.setText("magnitude accel " + xyz);
            countSteps();
            mTextView8.setText("steps " + peakCounter);

    }
}

3 个答案:

答案 0 :(得分:2)

 while (accelData.iterator().hasNext()) {

如果集合中至少有1个元素,则总是如此。

  1. accelData.iterator()每次都会创建新的迭代器,
  2. accelData.iterator().hasNext()每次检查收集的第一个元素
  3. 执行n ++直到达到结束并
  4. accelData.get(n + 1)抛出IndexOutOfBoundsException
  5. 您可以做的一件事是使用for循环。

     for (int n = 0; n < accelData.size() - 1; n++) {  // size-1 is used since you're accessing n+1 index
         if (accelData.get(n) != accelData.get(n + 1)) {
             if (accelData.get(n) > accelData.get(n + 1)) {
                    if (accelData.get(n) >= controlPoint) {
                        if (accelData.get(n) < avg * factor) {
                            underAvgCounter++;
                        }
                        peakCounter++;                        
                    }
            } else {
                controlPoint = accelData.get(n + 1);
            }
        } 
    }
    peakCounter -= underAvgCounter;
    

答案 1 :(得分:1)

Iterator it = accelData.iterator();
while(it.hasNext()) {
  float elem = it.next();
  ...
}

答案 2 :(得分:0)

使用IndexOutOfBounds时,以下代码代码段是一个问题:

accelData.get(n)和accelData.get(n + 1)

您正在检查iterator()。hasNext(),但它并不保证存在n + 1个元素。

无限循环,我认为是因为你从未使用过iterator()。next()来遍历下一个元素。请参阅一个简单的迭代器代码以便更好地理解。

你可以在java中使用任何循环技术,例如for,do while,while和advanced for循环,这无关紧要。重要的是,如果你有效地做它并且可读。