Массив, всегда возвращающий нуль - PullRequest
0 голосов
/ 28 июля 2011

Я создаю приложение для Android, которое считывает файл из папки, генерирует из него массив, затем наносит на карту точки широты + долготы массива на карте. Сначала я разработал метод возврата массива как метод void в отдельной программе (и он функционировал должным образом). Единственными изменениями, которые я сделал, было возвращение массива, чтобы приложение Android могло его использовать. Тем не менее, я всегда получаю силу закрытия. После некоторой отладки я обнаружил, что мой метод каждый раз возвращал 'null' (я установил оператор if, говорящий, что если массив равен null, отобразите экран с надписью "FAIL!" - и приложение всегда показывает "FAIL!") ,

Я проверил, чтобы убедиться, что файл находится в правильном месте - это определенно так. Тем не менее, я не уверен, почему программа возвращает ноль? Вот мой код:

package net.learn2develop.GoogleMaps;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.List;
import java.util.StringTokenizer;

import com.google.android.maps.GeoPoint;
import com.google.android.maps.MapActivity;
import com.google.android.maps.MapController;
import com.google.android.maps.MapView;
import com.google.android.maps.Overlay;
import com.google.android.maps.MapView.LayoutParams;

import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Point;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;


public class MapsActivity extends MapActivity 
{    
    MapView mapView; 
    MapController mc;
    GeoPoint p;
    GeoPoint p2;
    GeoPoint p99;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    // Map code goes here.....


    // Add points from ReadCsv.java
    File fileToUse = new File("/Users/csrobot/Desktop/TrainingData/Training4.csv");
    String[][] bump = getArray(fileToUse);
    if(bump == null){
        setContentView(R.layout.deleteme);
    }
//      for(int i = 0; i < bump.length; i++) {
//          String coordinates99[] = {bump[i][0], bump[i][1]};
//          double lat99 = Double.parseDouble(coordinates99[0]);
//          double lng99 = Double.parseDouble(coordinates99[1]);
//          p99 = new GeoPoint(
//                  (int) (lat99 * 1E6),
//                  (int) (lng99 * 1E6));
//          MapOverlay mapOverlay99 = new MapOverlay();
//          List<Overlay> listOfOverlays99 = mapView.getOverlays();
//          listOfOverlays99.add(mapOverlay99);
//      } 

    mapView.invalidate();
}

@Override
protected boolean isRouteDisplayed() {
    return false;
}

public String[][] getArray(File file) {

    try {
        int row = 0;
        int col = 0;
        String[][] numbers=new String[5258][16];

        BufferedReader bufRdr;
        bufRdr = new BufferedReader(new FileReader(file));
        String line = null;

        //read each line of text file
        while((line = bufRdr.readLine()) != null) {
            StringTokenizer st = new StringTokenizer(line,",");
            col=0;

            while (st.hasMoreTokens()) {
                //get next token and store it in the array
                numbers[row][col] = st.nextToken();
                col++;
            }
            row++;
        }

        // ... Here is the code that will make the array
                    // ...   

        //close the file
        bufRdr.close();

        return arrayOfBumps;

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } catch(Exception e) {
                // System.out.println("The following error occurred "+e);
    }
    return null;

}

Так вот как выглядит моя деятельность. Мой logcat до добавления оператора if (bump == null) и удаления комментария к циклу for, который следует за ним, был:

07-28 09:11:10.962: ERROR/AndroidRuntime(13014): FATAL EXCEPTION: main  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014): java.lang.RuntimeException: Unable to start activity ComponentInfo{net.learn2develop.GoogleMaps/net.learn2develop.GoogleMaps.MapsActivity}: java.lang.NullPointerException  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.os.Handler.dispatchMessage(Handler.java:99)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.os.Looper.loop(Looper.java:123)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread.main(ActivityThread.java:4627)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at java.lang.reflect.Method.invokeNative(Native Method)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at java.lang.reflect.Method.invoke(Method.java:521)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at dalvik.system.NativeStart.main(Native Method)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014): Caused by: java.lang.NullPointerException  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at net.learn2develop.GoogleMaps.MapsActivity.onCreate(MapsActivity.java:89)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)  
07-28 09:11:10.962: ERROR/AndroidRuntime(13014):     ... 11 more  

Так может кто-нибудь помочь мне здесь? Я был в этом в течение нескольких дней и до сих пор не могу понять это.

1 Ответ

2 голосов
/ 28 июля 2011

File fileToUse = new File("/Users/csrobot/Desktop/TrainingData/Training4.csv");

Это источник NullPointerException.

Путь к файлу должен быть в этой форме /data/data/yourpackagename/somefolder/yourfile

Вы не можете сделатьэто такФайл должен храниться в памяти эмулятора / телефона.Вы должны поместить файл в данные эмулятора, например, переместить CSV-файл в assets/raw resource, а затем загрузить его в InputStreamReader объект и сделать то, что вы запланировали.Найдите еще несколько примеров открытия файла из папки assets или res/raw folder

...