当前位置: 首页>>代码示例>>Java>>正文


Java CodeIterator.lookAhead方法代码示例

本文整理汇总了Java中javassist.bytecode.CodeIterator.lookAhead方法的典型用法代码示例。如果您正苦于以下问题:Java CodeIterator.lookAhead方法的具体用法?Java CodeIterator.lookAhead怎么用?Java CodeIterator.lookAhead使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在javassist.bytecode.CodeIterator的用法示例。


在下文中一共展示了CodeIterator.lookAhead方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: scan

import javassist.bytecode.CodeIterator; //导入方法依赖的package包/类
private void scan(int pos, CodeIterator iter, Subroutine sub) throws BadBytecode {
    // Skip already processed blocks
    if (done.contains(Integer.valueOf(pos)))
        return;

    done.add(Integer.valueOf(pos));

    int old = iter.lookAhead();
    iter.move(pos);

    boolean next;
    do {
        pos = iter.next();
        next = scanOp(pos, iter, sub) && iter.hasNext();
    } while (next);

    iter.move(old);
}
 
开发者ID:AndreJCL,项目名称:JCL,代码行数:19,代码来源:SubroutineScanner.java

示例2: runEditor

import javassist.bytecode.CodeIterator; //导入方法依赖的package包/类
protected void runEditor(ExprEditor ed, CodeIterator oldIterator)
    throws CannotCompileException
{
    CodeAttribute codeAttr = oldIterator.get();
    int orgLocals = codeAttr.getMaxLocals();
    int orgStack = codeAttr.getMaxStack();
    int newLocals = locals();
    codeAttr.setMaxStack(stack());
    codeAttr.setMaxLocals(newLocals);
    ExprEditor.LoopContext context
        = new ExprEditor.LoopContext(newLocals);
    int size = oldIterator.getCodeLength();
    int endPos = oldIterator.lookAhead();
    oldIterator.move(currentPos);
    if (ed.doit(thisClass, thisMethod, context, oldIterator, endPos))
        edited = true;

    oldIterator.move(endPos + oldIterator.getCodeLength() - size);
    codeAttr.setMaxLocals(orgLocals);
    codeAttr.setMaxStack(orgStack);
    maxLocals = context.maxLocals;
    maxStack += context.maxStack;
}
 
开发者ID:AndreJCL,项目名称:JCL,代码行数:24,代码来源:Expr.java

示例3: scan

import javassist.bytecode.CodeIterator; //导入方法依赖的package包/类
private void scan(int pos, CodeIterator iter, Subroutine sub) throws BadBytecode {
    // Skip already processed blocks
    if (done.contains(new Integer(pos)))
        return;

    done.add(new Integer(pos));

    int old = iter.lookAhead();
    iter.move(pos);

    boolean next;
    do {
        pos = iter.next();
        next = scanOp(pos, iter, sub) && iter.hasNext();
    } while (next);

    iter.move(old);
}
 
开发者ID:MeRPG2,项目名称:EndHQ-Libraries,代码行数:19,代码来源:SubroutineScanner.java

示例4: analyze

import javassist.bytecode.CodeIterator; //导入方法依赖的package包/类
/**
 * Performs data-flow analysis on a method and returns an array, indexed by
 * instruction position, containing the starting frame state of all reachable
 * instructions. Non-reachable code, and illegal code offsets are represented
 * as a null in the frame state array. This can be used to detect dead code.
 *
 * If the method does not contain code (it is either native or abstract), null
 * is returned.
 *
 * @param clazz the declaring class of the method
 * @param method the method to analyze
 * @return an array, indexed by instruction position, of the starting frame state,
 *         or null if this method doesn't have code
 * @throws BadBytecode if the bytecode does not comply with the JVM specification
 */
public Frame[] analyze(CtClass clazz, MethodInfo method) throws BadBytecode {
    this.clazz = clazz;
    CodeAttribute codeAttribute = method.getCodeAttribute();
    // Native or Abstract
    if (codeAttribute == null)
        return null;

    int maxLocals = codeAttribute.getMaxLocals();
    int maxStack = codeAttribute.getMaxStack();
    int codeLength = codeAttribute.getCodeLength();

    CodeIterator iter = codeAttribute.iterator();
    IntQueue queue = new IntQueue();

    exceptions = buildExceptionInfo(method);
    subroutines = scanner.scan(method);

    Executor executor = new Executor(clazz.getClassPool(), method.getConstPool());
    frames = new Frame[codeLength];
    frames[iter.lookAhead()] = firstFrame(method, maxLocals, maxStack);
    queue.add(iter.next());
    while (!queue.isEmpty()) {
        analyzeNextEntry(method, iter, queue, executor);
    }

    return frames;
}
 
开发者ID:AndreJCL,项目名称:JCL,代码行数:43,代码来源:Analyzer.java

示例5: lookAhead

import javassist.bytecode.CodeIterator; //导入方法依赖的package包/类
private int lookAhead(CodeIterator iter, int pos) throws BadBytecode {
    if (! iter.hasNext())
        throw new BadBytecode("Execution falls off end! [pos = " + pos + "]");

    return iter.lookAhead();
}
 
开发者ID:AndreJCL,项目名称:JCL,代码行数:7,代码来源:Analyzer.java


注:本文中的javassist.bytecode.CodeIterator.lookAhead方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。