[jbossseam-issues] [JBoss JIRA] Closed: (JBSEAM-2192) AbstractMap from org.jboss.seam.international.Messages needs containsKey()
Pete Muir (JIRA)
jira-events at lists.jboss.org
Sun Dec 2 12:25:18 EST 2007
[ http://jira.jboss.com/jira/browse/JBSEAM-2192?page=all ]
Pete Muir closed JBSEAM-2192.
-----------------------------
> AbstractMap from org.jboss.seam.international.Messages needs containsKey()
> --------------------------------------------------------------------------
>
> Key: JBSEAM-2192
> URL: http://jira.jboss.com/jira/browse/JBSEAM-2192
> Project: JBoss Seam
> Issue Type: Bug
> Components: Core
> Affects Versions: 2.0.0.CR2
> Environment: Mac OSX, Jboss 4.2.1
> Reporter: Damian Harvey
> Assigned To: Pete Muir
> Fix For: 2.0.1.GA
>
>
> Performing a containsKey() on the AbstractMap from org.jboss.seam.international.Messages results in severe performance problems (800ms on 1,800 properties compared to under 1ms for a get())
> eg:
> @In
> Map<String, String> messages; //This is the Seam messages bundle
> public void aMethod() {
> if(messages.containsKey("key.mykey")) {
> //do something
> }
> }
>
> I traced the containsKey for a while but it went on a mad run through ELResolvers and Pages.java etc.
> Simple solution is to add a containsKey to the AbstractMap:
> public boolean containsKey(String key) {
> if(messages.get(key).equals(key)) {
> return false;
> } else {
> return true;
> }
> }
> Would be nice to know why this 'mad run' happened though. Hopefully not symptomatic of something wrong deeper down.
> Cheers,
> Damian.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://jira.jboss.com/jira/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the seam-issues
mailing list