我试图让客户设定他们想要预订的日期和时间。我已经完成的代码在保存时会在文本文件中创建大量文本,并在您尝试再次加载时崩溃。
这是我添加预订的代码:
public static List<Reservation> addReservations(List<Reservation> reservations, List<Customer> customers) {
int newReservationId = Reservation.getNumberOfReservations() + 1;
String startString = readString("Enter Reservation date");
SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
Date date = null;
try {
date = sdf.parse(startString);
} catch (ParseException ex) {
Logger.getLogger(ProjectIncrement5.class.getName()).log(Level.SEVERE, null, ex);
}
Calendar dateTime = Calendar.getInstance();
dateTime.setTime(date);
listCustomers(customers, reservations);
int reservationCustomerId = readInt("Enter Customer Id", Customer.getNumberOfCustomers(), 1);
Customer reservationCustomer = customers.get(reservationCustomerId - 1);
Reservation res = new Reservation(newReservationId, dateTime, reservationCustomer);
reservations.add(res);
return reservations;
}
预订舱位:
public class Reservation {
private int reservationId;
private Calendar dateTime;
private Customer customer;
private static int numberOfReservations = 0;
public Reservation() {
this.reservationId = 0;
this.dateTime = null;
this.customer = null;
numberOfReservations++;
}
public Reservation(int reservationId, Calendar dateTime, Customer customer) {
this.reservationId = reservationId;
this.dateTime = dateTime;
this.customer = customer;
numberOfReservations++;
}
public static int getNumberOfReservations() {
return numberOfReservations;
}
public int getReservationId() {
return reservationId;
}
public void setreservationId(int reservationId) {
this.reservationId = reservationId;
}
public Calendar getDateTime() {
return dateTime;
}
public Customer getCustomer()
{
return customer;
}
public void setCustomer(Customer customer)
{
this.customer = customer;
}
public String setDateTime() {
SimpleDateFormat formatter = new SimpleDateFormat("dd/MM/yyyy");
String dateString = formatter.format(this.dateTime.getTime());
return dateString;
}
@Override
public String toString() {
return "Reservation id: " + getReservationId() + ", "
+ "Date/Time " + setDateTime() +
"customer: " + getCustomer();
}
}
这是保存到导致错误的文本文件中的内容:
1:java.util.GregorianCalendar中[时间= 851385600000,areFieldsSet =真,areAllFieldsSet =真,宽大=真,区= sun.util.calendar.ZoneInfo [ID = “欧洲/伦敦”,偏移= 0,dstSavings = 3600000,useDaylight =真,过渡= 242,lastRule = java.util.SimpleTimeZone中[ID =欧洲/伦敦,偏移= 0,dstSavings = 3600000,useDaylight =真,startYear = 0,STARTMODE = 2,startMonth = 2,朝九特派= -1,startDayOfWeek = 1,开始时间= 3600000,startTimeMode = 2,endMode = 2,endMonth = 9,endday指定= -1,一个endDayOfWeek = 1,结束时间= 3600000,endTimeMode = 2]],Firstdayofweek可= 2,minimalDaysInFirstWeek = 4 ,ERA = 1,YEAR = 1996,月= 11,WEEK_OF_YEAR = 52,WEEK_OF_MONTH = 4,DAY_OF_MONTH = 24,DAY_OF_YEAR = 359,DAY_OF_WEEK = 3,DAY_OF_WEEK_IN_MONTH = 4,AM_PM = 0,HOUR = 0,HOUR_OF_DAY = 0,MINUTE = 0,SECOND = 0,微差= 0,ZONE_OFFSET = 0,DST_OFFSET = 0]:4:其中
我认为在获取日历实例时会发生错误,但我不确定如何更简单地解决此问题并解决此问题。有人可以帮忙吗?
答案 0 :(得分:1)
问题是您将Calendar.toString()
而不是真实日期存储到文本文件中。
看看你发布的内容:
Firstdayofweek可= 2,minimalDaysInFirstWeek = 4,ERA = 1,的
YEAR=1996
强>,<强>MONTH=11
下,WEEK_OF_YEAR = 52,WEEK_OF_MONTH = 4,<强>DAY_OF_MONTH=24
下,DAY_OF_YEAR = 359,DAY_OF_WEEK = 3,DAY_OF_WEEK_IN_MONTH = 4,AM_PM = 0,的HOUR=0
下,HOUR_OF_DAY = 0,的 {{ 1}} 强>,<强>MINUTE=0
下,微差= 0,ZONE_OFFSET = 0,DST_OFFSET = 0]
这似乎是一个正确的日期。我会说更多,这似乎是一个非常完整的日期,有很多信息没有? ;)
我不知道该日期应该如何存储,但是,例如,如果您想以SECOND=0
格式存储日期,请使用以下代码行来检查它是否为“sa”有效日期(您已在代码中执行此操作)。
dd/MM/yyyy
检查完毕后,如果SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
date = sdf.parse(startString);
有效,则您不需要创建任何startString
实例,只需将Calendar
写入文本文件
所以在我的
startString
课程中,我没有:Reservation
我会把它拿出来,只有:私人private Calendar dateTime
?
NOPE。这个想法是:
String startString
(Object
即可,但日期也是如此)Calendar
发送人类可读日期。很抱歉,但我无法更具体,我无法执行您的代码,因为缺少很多部分(String
,Customer
,readInt
等...)。
答案 1 :(得分:1)
我接受Jordi Castilla的答案,并且还想告诉其他选项也这样做。
在这里你节省了日期&amp;使用Calendar.toString()
方法进行归档的时间,您可以使用以下代码
DateFormat df = new SimpleDateFormat("MM/dd/yyyy HH:mm:ss");
String stringToFile = df.format(date);//you can send this string to the file which you want to store the Date & Time
答案 2 :(得分:1)
现代方法使用java.time类。避免使用麻烦,混乱和设计不良的旧遗留日期时间类,例如Calendar
。
LocalDate
收集日期部分。如果输入错误,请抓住任何DateTimeParseException
。
DateTimeFormatter f = DateTimeFormatter.ofPattern( "dd/MM/uuuu" ) ;
try {
LocalDate ld = LocalDate.parse( input , f ) ;
} catch ( DateTimeParseException e ) {
…
}
好像你没有明确跟踪时间。所以LocalDate
类就足够了。
将数据序列化为文本文件时,应使用标准ISO 8601格式。这些格式是实用的和明确,易于通过机器解析,易于跨文化的人阅读,而不是假设英语熟练。
在解析和生成字符串时,java.time类默认使用标准格式。只需致电toString
即可生成。
String output = ld.toString() ; // Ex: 2017-01-23
java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.Date
,Calendar
和&amp; SimpleDateFormat
现在位于Joda-Time的maintenance mode项目建议迁移到java.time类。
要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310。
从哪里获取java.time类?
ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如Interval
,YearWeek
,YearQuarter
和more。