Нулевой вывод генерируется при использовании BufferedReader / PrintWriter - PullRequest
0 голосов
/ 20 ноября 2018

Также может показаться, что я не могу прочитать файл.

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package daos;

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.PrintWriter;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
import model.City;
import model.YearData;

import repositories.Repository;

/**
 *
 * @author mga
 */
public class DAOTextImpl implements DAOInterface {

    static final char DELIMITER = ',';
    ArrayList yeardata=new ArrayList<>();

    @Override
    public Repository load(String filename) {

        Repository repository = new Repository();

        try (BufferedReader br = new BufferedReader(new FileReader(filename))) {

            String[] temp;
            String line = br.readLine();
            while (line != null) {

                temp = line.split(Character.toString(DELIMITER));
                int id = Integer.parseInt(temp[0]);
                String cityName = stripQuotes(temp[1]);
                String country = stripQuotes(temp[2]);


                int noOfLines = Integer.parseInt(temp[2]);
               // for (int i = 0; i < noOfLines; i++) 
              //  {
                    line = br.readLine();
                    temp = line.split(Character.toString(DELIMITER));
                    String year = stripQuotes(temp[0]);
                    float precipitation = Float.parseFloat(temp[1]);
                    int maxTemp = Integer.parseInt(temp[2]);
                    int minTemp = Integer.parseInt(temp[3]);
                    int windSpeed = Integer.parseInt(temp[4]);
                    String windDirection = stripQuotes(temp[5]);
                    yeardata.add(year);
                    yeardata.add(precipitation);
                    yeardata.add(maxTemp);
                    yeardata.add(minTemp);
                    yeardata.add(windSpeed);
                    yeardata.add(windDirection);
                    City city=new City(id,cityName,country,yeardata);

              //  }
                repository.add(city);
                line = br.readLine();
            }
            br.close();
        } catch (IOException ex) {
            Logger.getLogger(DAOTextImpl.class.getName()).log(Level.SEVERE, null, ex);
        }
        return repository;
    }

    @Override




    public void store(String filename, Repository repository) {
        try (PrintWriter output = new PrintWriter(filename)) {
         output.print(repository.toString());
         output.print(repository);


            output.close();
        } catch (FileNotFoundException ex) {
            Logger.getLogger(DAOTextImpl.class.getName()).log(Level.SEVERE, null, ex);
        }        
    }

    private String stripQuotes(String str) {
        return str.substring(1, str.length() - 1);
    }
}

Мой класс репозитория выглядит следующим образом:

package repositories;

import daos.DAOTextImpl;
import java.util.ArrayList;
import java.util.function.Predicate;
import model.City;
import model.YearData;


public class Repository implements RepositoryInterface {
    private ArrayList<City> items; 
     static char DELIMITER=',';

    public Repository() {
        this.items = new ArrayList<>();

    }

    public Repository(ArrayList <City> items) {        
        this.items = items;
    }

    public Repository(String filename) {
        this();
        // Create dao and execute load  
        DAOTextImpl dao = new DAOTextImpl();
    }

    @Override
    public ArrayList<City> getItems() {        
        return this.items;
    }

    @Override
    public void setItems(ArrayList<City> items) {        
        this.items = items;
    }

    @Override
    public void add(City items) {

        this.items.add(items);

    }

    @Override
    public void remove(int id) {
        Predicate<City> predicate = e->e.getId() == id;       
        this.items.removeIf(predicate);
    }

   @Override
    public City getItem(int id) {

        for (City item:this.items) {
            if (item.getId() == id)
                return item;
        }
        return null;
    }

    @Override
    public String toString() {
           System.out.println(items);

        return "\nItems: " + this.items;

    }    

    @Override
    public void store(String filename) {       
        // create dao and execute store    
        DAOTextImpl dao = new DAOTextImpl();
        dao.store(filename, this); 
    }        


}

У меня есть стресс-тестирование программы,вставив несколько output.print(repository.toString()); операторов внутри него.Например, вставка 20 операторов output.print(repository.toString()); вставит в сгенерированный файл 20 items:[], что заставит меня подумать, что в классе / интерфейсе репозитория есть ошибка, но я на всю жизнь совершенно не уверенотносительно того, как / почему это генерируется.

Я не уверен, связан ли факт, что файлы, кажется, не читаются должным образом, с этой проблемой в настоящее время, или, скорее, одна ошибка просто маскирует другую,

В силу того, что я не уверен в том, что является причиной проблемы, я чувствую, что мне нужно включить всю длину кода, хотя бы для облегчения процесса проверки ошибок.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...