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

📄 localvariableinstruction.java

📁 代码是一个分类器的实现,其中使用了部分weka的源代码。可以将项目导入eclipse运行
💻 JAVA
字号:
package de.fub.bytecode.generic;import java.io.*;import de.fub.bytecode.util.ByteSequence;import de.fub.bytecode.classfile.Utility;import de.fub.bytecode.Constants;/** * Abstract super class for instructions dealing with local variables. * * @version $Id: LocalVariableInstruction.java,v 1.10 2001/08/28 10:28:05 dahm Exp $ * @author  <A HREF="http://www.berlin.de/~markus.dahm/">M. Dahm</A> */public abstract class LocalVariableInstruction extends Instruction  implements TypedInstruction, IndexedInstruction {  protected int     n         = -1; // index of referenced variable  private short     c_tag     = -1; // compact version, such as ILOAD_0  private short     canon_tag = -1; // canonical tag such as ILOAD  private final boolean wide() { return n > Constants.MAX_BYTE; }  /**   * Empty constructor needed for the Class.newInstance() statement in   * Instruction.readInstruction(). Not to be used otherwise.   * tag and length are defined in readInstruction and initFromFile, respectively.   */  LocalVariableInstruction(short canon_tag, short c_tag) {    super();    this.canon_tag = canon_tag;    this.c_tag     = c_tag;  }  /**   * Empty constructor needed for the Class.newInstance() statement in   * Instruction.readInstruction(). Also used by IINC()!   */  LocalVariableInstruction() {  }  /**   * @param opcode Instruction opcode   * @param c_tag Instruction number for compact version, ALOAD_0, e.g.   * @param n local variable index (unsigned short)   */  protected LocalVariableInstruction(short opcode, short c_tag, int n) {    super(opcode, (short)2);    this.c_tag = c_tag;    canon_tag  = opcode;    setIndex(n);  }  /**   * Dump instruction as byte code to stream out.   * @param out Output stream   */  public void dump(DataOutputStream out) throws IOException {    if(wide()) // Need WIDE prefix ?      out.writeByte(Constants.WIDE);    out.writeByte(opcode);    if(length > 1) { // Otherwise ILOAD_n, instruction, e.g.      if(wide())	out.writeShort(n);      else	out.writeByte(n);    }  }  /**   * Long output format:   *   * &lt;name of opcode&gt; "["&lt;opcode number&gt;"]"    * "("&lt;length of instruction&gt;")" "&lt;"&lt; local variable index&gt;"&gt;"   *   * @param verbose long/short format switch   * @return mnemonic for instruction   */  public String toString(boolean verbose) {    if(((opcode >= Constants.ILOAD_0) &&	(opcode <= Constants.ALOAD_3)) ||       ((opcode >= Constants.ISTORE_0) &&	(opcode <= Constants.ASTORE_3)))      return super.toString(verbose);    else      return super.toString(verbose) + " " + n;  }  /**   * Read needed data (e.g. index) from file.   * PRE: (ILOAD <= tag <= ALOAD_3) || (ISTORE <= tag <= ASTORE_3)   */  protected void initFromFile(ByteSequence bytes, boolean wide)    throws IOException  {    if(wide) {      n         = bytes.readUnsignedShort();      length    = 4;    } else if(((opcode >= Constants.ILOAD) &&	       (opcode <= Constants.ALOAD)) ||	      ((opcode >= Constants.ISTORE) &&	       (opcode <= Constants.ASTORE))) {      n      = bytes.readUnsignedByte();      length = 2;    } else if(opcode <= Constants.ALOAD_3) { // compact load instruction such as ILOAD_2      n      = (opcode - Constants.ILOAD_0) % 4;      length = 1;    } else { // Assert ISTORE_0 <= tag <= ASTORE_3      n      = (opcode - Constants.ISTORE_0) % 4;      length = 1;    } }  /**   * @return local variable index  referred by this instruction.   */  public final int getIndex() { return n; }  /**   * Set the local variable index   */  public void setIndex(int n) {     if((n < 0) || (n > Constants.MAX_SHORT))      throw new ClassGenException("Illegal value: " + n);    this.n = n;    if(n >= 0 && n <= 3) { // Use more compact instruction xLOAD_n      opcode = (short)(c_tag + n);      length = 1;    } else {      opcode = canon_tag;            if(wide()) // Need WIDE prefix ?	length = 4;      else	length = 2;    }  }  /** @return canonical tag for instruction, e.g., ALOAD for ALOAD_0   */  public short getCanonicalTag() {    return canon_tag;  }  /**   * Returns the type associated with the instruction -    * in case of ALOAD or ASTORE Type.OBJECT is returned.   * This is just a bit incorrect, because ALOAD and ASTORE   * may work on every ReferenceType (including Type.NULL) and   * ASTORE may even work on a ReturnaddressType .   * @return type associated with the instruction   */  public Type getType(ConstantPoolGen cp) {    switch(canon_tag) {    case Constants.ILOAD: case Constants.ISTORE:       return Type.INT;    case Constants.LLOAD: case Constants.LSTORE:       return Type.LONG;    case Constants.DLOAD: case Constants.DSTORE:       return Type.DOUBLE;    case Constants.FLOAD: case Constants.FSTORE:       return Type.FLOAT;    case Constants.ALOAD: case Constants.ASTORE:      return Type.OBJECT;    default: throw new ClassGenException("Oops: unknown case in switch" + canon_tag);    }  }}

⌨️ 快捷键说明

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