Link to home
Start Free TrialLog in
Avatar of AndyC1000
AndyC1000

asked on

Accessing keys in Map<Long, Double>

Dear all,

I'm using the store in map method to create a map with a long key with 30min timesteps and a double value.  I'm using a long and the Calendar object instead of the Date.  It works and stores the data and prints to console.  See first code block and bottom of post for output to console.

My issue the map isn't returning the correct information,   See unit test below.    The aim of the unit test is to retrieve date information and timestep for the given long key. I'm not able to see the issue.

Thanks

 An example of the output is
Timestep: Fri Mar 13 01:00:00 EST 2015 13 2 2015 1 0 0
Timestep: Fri Mar 13 04:30:00 EST 2015 13 2 2015 4 30 0
Timestep: Fri Mar 13 08:00:00 EST 2015 13 2 2015 8 0 0
Timestep: Fri Mar 13 11:30:00 EST 2015 13 2 2015 11 30 0
Timestep: Fri Mar 13 15:00:00 EST 2015 13 2 2015 15 0 0
Timestep: Fri Mar 13 18:30:00 EST 2015 13 2 2015 18 30 0
Timestep: Fri Mar 13 22:00:00 EST 2015 13 2 2015 22 0 0
Timestep: Fri Mar 13 05:30:00 EST 2015 13 2 2015 5 30 0
Timestep: Fri Mar 13 09:00:00 EST 2015 13 2 2015 9 0 0
Timestep: Fri Mar 13 12:30:00 EST 2015 13 2 2015 12 30 0
Timestep: Fri Mar 13 16:00:00 EST 2015 13 2 2015 16 0 0
Timestep: Fri Mar 13 19:30:00 EST 2015 13 2 2015 19 30 0
Timestep: Fri Mar 13 23:00:00 EST 2015 13 2 2015 23 0 0
Timestep: Fri Mar 13 13:00:00 EST 2015 13 2 2015 13 0 0
Timestep: Fri Mar 13 16:30:00 EST 2015 13 2 2015 16 30 0
Timestep: Fri Mar 13 20:00:00 EST 2015 13 2 2015 20 0 0
Timestep: Fri Mar 13 23:30:00 EST 2015 13 2 2015 23 30 0

start = new SimpleDateFormat("dd/MM/yyyy").parse("13/03/2015")
				.getTime();
endDate = new SimpleDateFormat("dd/MM/yyyy").parse("14/03/2015")
				.getTime();
public Map<Long, Double> storeInMap(long start, long end) {
		Map<Long, Double> map = new HashMap<>();
		long timeMS = start;
		while (timeMS < end) {
			// Store the data in the map
			map.put(timeMS, 0.0); // 0.0 default value

			// Move ahead 30 mins in milliseconds
			timeMS += TimeUnit.MILLISECONDS.convert(30L, TimeUnit.MINUTES);
			System.out.println(new Date(timeMS));
		}
		return map;
	}

Open in new window


Unit test.

@Test
	public void testFindTimestepFromMap() {
		map = util.storeInMap(startDate, endDate);
		for (Map.Entry<Long, Double> entry : map.entrySet()) {
			Long timestep = entry.getKey();
			Calendar calt = Calendar.getInstance();
			calt.setTimeInMillis(timestep);
			System.out.println("Timestep: " + calt.getTime() + " "
					+ calt.get(Calendar.DAY_OF_MONTH) + " "
					+ calt.get(Calendar.MONTH) + " " + calt.get(Calendar.YEAR)
					+ " " + calt.get(Calendar.HOUR_OF_DAY) + " "
					+ calt.get(Calendar.MINUTE) + " "
					+ calt.get(Calendar.SECOND));
		}

	}

Open in new window



Output of store in map method:
Fri Mar 13 00:30:00 EST 2015
Fri Mar 13 01:00:00 EST 2015
Fri Mar 13 01:30:00 EST 2015
Fri Mar 13 02:00:00 EST 2015
Fri Mar 13 02:30:00 EST 2015
Fri Mar 13 03:00:00 EST 2015
Fri Mar 13 03:30:00 EST 2015
Fri Mar 13 04:00:00 EST 2015
Fri Mar 13 04:30:00 EST 2015
Fri Mar 13 05:00:00 EST 2015
Fri Mar 13 05:30:00 EST 2015
Fri Mar 13 06:00:00 EST 2015
Fri Mar 13 06:30:00 EST 2015
Fri Mar 13 07:00:00 EST 2015
Fri Mar 13 07:30:00 EST 2015
Fri Mar 13 08:00:00 EST 2015
Fri Mar 13 08:30:00 EST 2015
Fri Mar 13 09:00:00 EST 2015
Fri Mar 13 09:30:00 EST 2015
Fri Mar 13 10:00:00 EST 2015
Fri Mar 13 10:30:00 EST 2015
Fri Mar 13 11:00:00 EST 2015
Fri Mar 13 11:30:00 EST 2015
Fri Mar 13 12:00:00 EST 2015
Fri Mar 13 12:30:00 EST 2015
Fri Mar 13 13:00:00 EST 2015
Fri Mar 13 13:30:00 EST 2015
Fri Mar 13 14:00:00 EST 2015
Fri Mar 13 14:30:00 EST 2015
Fri Mar 13 15:00:00 EST 2015
Fri Mar 13 15:30:00 EST 2015
Fri Mar 13 16:00:00 EST 2015
Fri Mar 13 16:30:00 EST 2015
Fri Mar 13 17:00:00 EST 2015
Fri Mar 13 17:30:00 EST 2015
Fri Mar 13 18:00:00 EST 2015
Fri Mar 13 18:30:00 EST 2015
Fri Mar 13 19:00:00 EST 2015
Fri Mar 13 19:30:00 EST 2015
Fri Mar 13 20:00:00 EST 2015
Fri Mar 13 20:30:00 EST 2015
Fri Mar 13 21:00:00 EST 2015
Fri Mar 13 21:30:00 EST 2015
Fri Mar 13 22:00:00 EST 2015
Fri Mar 13 22:30:00 EST 2015
Fri Mar 13 23:00:00 EST 2015
Fri Mar 13 23:30:00 EST 2015
Sat Mar 14 00:00:00 EST 2015
ASKER CERTIFIED SOLUTION
Avatar of mccarl
mccarl
Flag of Australia image

Link to home
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Start Free Trial
SOLUTION
Link to home
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Start Free Trial
Avatar of dpearson
dpearson

Oops - ships passing in the night :)
;) No worries