From 0ea58626701de1008cf2984d393527d00d3c5fcc Mon Sep 17 00:00:00 2001 From: Guoxiong Li Date: Fri, 22 Jan 2021 15:47:05 +0000 Subject: [PATCH] 8260053: Optimize Tokens' use of Names Reviewed-by: mcimadamore --- .../com/sun/tools/javac/parser/Tokens.java | 48 +++++-------------- 1 file changed, 13 insertions(+), 35 deletions(-) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Tokens.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Tokens.java index bd61dcf8ad2..2635b7a2035 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Tokens.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/Tokens.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,17 +25,14 @@ package com.sun.tools.javac.parser; +import java.util.HashMap; import java.util.Locale; +import java.util.Map; import com.sun.tools.javac.api.Formattable; import com.sun.tools.javac.api.Messages; import com.sun.tools.javac.parser.Tokens.Token.Tag; -import com.sun.tools.javac.util.List; -import com.sun.tools.javac.util.Name; -import com.sun.tools.javac.util.Context; -import com.sun.tools.javac.util.Filter; -import com.sun.tools.javac.util.ListBuffer; -import com.sun.tools.javac.util.Names; +import com.sun.tools.javac.util.*; /** A class that defines codes/utilities for Java source tokens * returned from lexical analysis. @@ -52,15 +49,7 @@ public class Tokens { /** * Keyword array. Maps name indices to Token. */ - private final TokenKind[] key; - - /** The number of the last entered keyword. - */ - private int maxKey = 0; - - /** The names of all tokens. - */ - private Name[] tokenName = new Name[TokenKind.values().length]; + private Map keywords = new HashMap<>(); public static final Context.Key tokensKey = new Context.Key<>(); @@ -75,24 +64,11 @@ public class Tokens { context.put(tokensKey, this); names = Names.instance(context); for (TokenKind t : TokenKind.values()) { - if (t.name != null) - enterKeyword(t.name, t); - else - tokenName[t.ordinal()] = null; + if (t.name != null) { + names.fromString(t.name); + keywords.put(t.name, t); + } } - - key = new TokenKind[maxKey+1]; - for (int i = 0; i <= maxKey; i++) key[i] = TokenKind.IDENTIFIER; - for (TokenKind t : TokenKind.values()) { - if (t.name != null) - key[tokenName[t.ordinal()].getIndex()] = t; - } - } - - private void enterKeyword(String s, TokenKind token) { - Name n = names.fromString(s); - tokenName[token.ordinal()] = n; - if (n.getIndex() > maxKey) maxKey = n.getIndex(); } /** @@ -101,11 +77,13 @@ public class Tokens { * identifier token is returned. */ TokenKind lookupKind(Name name) { - return (name.getIndex() > maxKey) ? TokenKind.IDENTIFIER : key[name.getIndex()]; + TokenKind t = keywords.get(name.toString()); + return (t != null) ? t : TokenKind.IDENTIFIER; } TokenKind lookupKind(String name) { - return lookupKind(names.fromString(name)); + TokenKind t = keywords.get(name); + return (t != null) ? t : TokenKind.IDENTIFIER; } /**