You have a few options.
- Create a static isValid(String emailAddress) method that returns a
boolean.
- Create a static void validate(String emailAddress) method that throws an
exception.
- Create a boolean isValid() method and accept any, even invalid, strings
in the constructor.

Either way you don't really want to invoke that setter method from the
constructor. The "this.value" reference should be set instead.

Generally speaking I would go for isValid() method and accept any string. I
personally don't really like exceptions being thrown in constructors unless
it's something like a null check. Even then assertions can be better.

--
James R. Perkins


On Tue, Feb 21, 2012 at 13:58, Hockchai Lim
<lim.hock-chai@xxxxxxxxxxxxxxx>wrote:

Assuming that I've a simply emailAddresss class that looks like below

public class EmailAddress {

private String value = "";

public EmailAddress( String newValue )
setValue( newValue );
}
. . .
}


Assuming that I now need to be able valid the emailAddress to make sure the
value contains a valid email address. In OO, what is the normal way to
handle this:
-> do I change the constructor to now throws an exception when newValue is
not in valid email address format.
or
-> do I add a public method in this class that can be executed to determine
if value contains valid email address after the EmailAddress object is
created.
or
-> Do I create a new validation class that validate the EmailAddress

thanks


--
This is the Java Programming on and around the IBM i (JAVA400-L) mailing
list
To post a message email: JAVA400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/java400-l
or email: JAVA400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/java400-l.



As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2022 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.