English 中文(简体)
Java Checking number months
原标题:

I think I figure out what question I am trying to ask I dont want get(Calendar.MONTH) I want the month not to be greater than the last caldendar month that is why i am doing month -1, i realize that if i use get(calendar.MONTH) it is getting month of november I just want to see check and make sure its not a greater then the december to us 12 to the computer 11. that is why every other month is invalid that is the question I am trying to get an answer for!?

public Date(String inString)  
{
    int month;// is define by cutting up the inString like this
    int day; // same as month
    int getSlash;

    getSlash = inStr.indexOf( / );
    month = Integer.parseInt(inStr.substring(0,getSlash));
    day = Integer.parseInt(inStr.substring(getSlash + 1));

    inStr = String.format("%02d/%02d%n",month,day);// padformatting string
    inStr=  new SimpleDateFormat("MM/dd").format(new SimpleDateFormat("MM/dd").parse(inStr));// checking to see if a actualdate

    GregorianCalendar cal = new GregorianCalendar();

    // this is what I don t understand after reading

    if (month -1 > cal.get(Calendar.MONTH ) // how do I get it to say int of the month if the user types in 12 it gets invalid
    {
        System.out.Println("Invalid Month -> " + month");
    }

}

when I do this all but month 11 is considered not vailid any one know why? I can not figure it out.

最佳回答

Judging by these related questions, I think you have a number of problems before that.

You re trying to code something that is already coded using existing libraries. This redundant code is causing conflicts.

You may

A) Use an existing library.

B) Code the solution yourself to learn.

If you go for A you just need.

public Date toDate( String inStr ) {
    return new SimpleDateFormat("MM/dd").parse(inStr);
}

And that s it!

If you go for B, what you need to to is first create an algorithm ( in a paper sheet ) and describe what steps do you need to solve the problem.

like

  • Take the string
  • Split it in part by "/"
  • Convert them to numbers
  • Validate if the first number is between 1 and 31
  • Validate the month ( is in 1 and 12 )
  • If month is 2 then the day must be < 29

etc etc et

Once you have all those steps clearly defined, you may the proceed to the codification. Some of them will translate seamlessly and some other will need more work. For some steps you may create code that is not as good as it could be but it works and for other parts you just won t have a clue.

But if you don t have an algorithm, you ll be hitting walls over and over. And getting problems as the one you re describing.

First make it run in the paper in your own words, later find out how to code it.

Here s a related entry: Process to pass from problem to code: How did you learn?

问题回答

Parsing dates and times yourself is a bad idea - as is using Java s built-in functionality.

I can t tell exactly what you want to do or what s wrong, but I think it s safe to say that using Joda Time would be a good idea.

Then instead of using get with mystical constants - and adjusting for months being 0-based - you can just use ReadableDateTime.getMonthOfYear() or some other pleasantly-named method. Much nicer.

For instance, to get the current month, you d use:

int currentMonth = new DateTime().getMonthOfYear();

That uses the ISO calendar system and the current default time zone. Personally I m not too fond of defaulting the time zone, so you may want:

int currentMonth = new DateTime(DateTimeZone.UTC).getMonthOfYear();

I suspect the ISO calendar system will be fine for you though :)

(As ChssPly76 says, cal.get(Calendar.MONTH) will get you the 0-based month number with your current code, but that s a horrible API in my opinion.)

EDIT: Now you ve updated your question, you should diagnose the problem by breaking it down a bit more. Is this a problem in terms of the user input, or comparing with the current month? If it s the "comparing with the current month" bit that s the problem, that s easy to show in a short but complete program which doesn t have all the rest of the stuff around it:

import java.util.*;

public class Test
{
    public static void main(String[] args)
    {
        // It s currently November
        int userInput = 11;

        Calendar cal = Calendar.getInstance();
        int currentMonth = cal.get(Calendar.MONTH) + 1;

        if (userInput == currentMonth)
        {
            System.out.println("Yes, that s the current month");
        }
        else
        {
            System.out.println("No, the current month is " + currentMonth);
        }
    }
}

I ve compensated for java.util.Calendar using 0 months by adding one to the value returned rather than subtracting one from the user input, but it s the same basic premise.

Now, if it s getting the user input which is the problem, you don t need to bother with the current month - just check whether you re getting what you expect.

A lot of programming is basically dividing a problem into two pieces. Here you have two issues:

  • Parsing user input
  • Comparing with the current month

Work out which one is the problem, and edit your question to address just that aspect.

I m guessing what you want is

cal.get(Calendar.MONTH)

which will return you zero-based index of month within year.

Your question is very unclear, however, and your parsing code seems a bit more involved than it has to be. Perhaps if you d explained better what you re trying to do, someone would be able to suggest a better approach.

I agree with the other answers; use SimpleDateFormat to parse, if the assignment allows you to.

You can also use the Calendar class to do something like this by switching lenient interpretation of values off, then setting the fields, and then forcing the Calendar instance to recompute it s internal counters. This will throw an exception if the field values are inconsistent. Like so:

import java.util.*;

public class Test {
    public static void main(String[] args) {
        Calendar c1=new GregorianCalendar();
        c1.setLenient(false);
        c1.set(2010,1,23);        // should work: Jan. 23, 2010
        c1.getTimeInMillis();     // will revalidate the calendar fields
        System.out.println("OK: "+c1.toString());
        try {
            c1.set(2010,2,35);     // invalid date: Feb. 35, 2010
            c1.getTimeInMillis();  // revalidate... should throw exception!
            System.out.println("OK: "+c1.toString()); // never happens
        } catch(IllegalArgumentException t) {
            System.out.println("FAIL: "+c1.toString());
            t.printStackTrace();
        }
    }
}

Here the calls to getTimeInMillis() force Calendar to revalidate its internal fields; the call will throw IllegalArgumentException if the values are inconsistent with normal Calendar time (i.e. out of range). If you d left the default of lenient=true enabled, the second call would succeed, but you d end up with a day in March as Calendar tries to figure out what you meant!

The only real catch is that to do a computation like this properly, you must know what the year is so that Calendar can do leap year calculations for you to get the number of days in February correct.

If for some reason you really don t care about the year, you could just hardcode a year that you know isn t a leap year... like 2009. Be sure to document that you re doing something weird like that though! It s a bit of a hack, and that s often an indication that you re doing something in a less than optimal way!

But, as mentioned in the other answers, either SimpleDateFormat, or a little array-based lookup table is probably the easy and clean answer here.

Hope you find this educational.





相关问题
Spring Properties File

Hi have this j2ee web application developed using spring framework. I have a problem with rendering mnessages in nihongo characters from the properties file. I tried converting the file to ascii using ...

Logging a global ID in multiple components

I have a system which contains multiple applications connected together using JMS and Spring Integration. Messages get sent along a chain of applications. [App A] -> [App B] -> [App C] We set a ...

Java Library Size

If I m given two Java Libraries in Jar format, 1 having no bells and whistles, and the other having lots of them that will mostly go unused.... my question is: How will the larger, mostly unused ...

How to get the Array Class for a given Class in Java?

I have a Class variable that holds a certain type and I need to get a variable that holds the corresponding array class. The best I could come up with is this: Class arrayOfFooClass = java.lang....

SQLite , Derby vs file system

I m working on a Java desktop application that reads and writes from/to different files. I think a better solution would be to replace the file system by a SQLite database. How hard is it to migrate ...

热门标签