⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 charsetenumerator.java

📁 java语法解释器生成器
💻 JAVA
字号:
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * JFlex 1.4.2                                                             * * Copyright (C) 1998-2008  Gerwin Klein <lsf@jflex.de>                    * * All rights reserved.                                                    * *                                                                         * * This program is free software; you can redistribute it and/or modify    * * it under the terms of the GNU General Public License. See the file      * * COPYRIGHT for more information.                                         * *                                                                         * * This program is distributed in the hope that it will be useful,         * * but WITHOUT ANY WARRANTY; without even the implied warranty of          * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the           * * GNU General Public License for more details.                            * *                                                                         * * You should have received a copy of the GNU General Public License along * * with this program; if not, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                 * *                                                                         * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */package JFlex;/** * Enumerator for the elements of a CharSet. * * Does not implement java.util.Enumeration, but supports the same protocol. *   * @author Gerwin Klein * @version JFlex 1.4.2, $Revision: 358 $, $Date: 2008-05-27 16:28:29 +1000 (Tue, 27 May 2008) $ */final public class CharSetEnumerator {  private int index;  private int offset;  private long mask = 1;  private CharSet set;    public CharSetEnumerator(CharSet characters) {    set = characters;    while (index < set.bits.length && set.bits[index] == 0)       index++;    if (index >= set.bits.length) return;            while (offset <= CharSet.MOD && ((set.bits[index] & mask) == 0)) {      mask<<= 1;      offset++;    }  }  private void advance() {    do {      offset++;      mask<<= 1;    } while (offset <= CharSet.MOD && ((set.bits[index] & mask) == 0));    if (offset > CharSet.MOD) {      do         index++;      while (index < set.bits.length && set.bits[index] == 0);              if (index >= set.bits.length) return;              offset = 0;      mask = 1;            while (offset <= CharSet.MOD && ((set.bits[index] & mask) == 0)) {        mask<<= 1;        offset++;      }     }  }  public boolean hasMoreElements() {    return index < set.bits.length;  }  public int nextElement() {    int x = (index << CharSet.BITS) + offset;    advance();    return x;  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -