本文整理汇总了Java中jdk.internal.org.objectweb.asm.tree.LabelNode类的典型用法代码示例。如果您正苦于以下问题:Java LabelNode类的具体用法?Java LabelNode怎么用?Java LabelNode使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
LabelNode类属于jdk.internal.org.objectweb.asm.tree包,在下文中一共展示了LabelNode类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。
示例1: markSubroutines
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
/**
* Walks the method and determines which internal subroutine(s), if any,
* each instruction is a method of.
*/
private void markSubroutines() {
BitSet anyvisited = new BitSet();
// First walk the main subroutine and find all those instructions which
// can be reached without invoking any JSR at all
markSubroutineWalk(mainSubroutine, 0, anyvisited);
// Go through the head of each subroutine and find any nodes reachable
// to that subroutine without following any JSR links.
for (Iterator<Map.Entry<LabelNode, BitSet>> it = subroutineHeads
.entrySet().iterator(); it.hasNext();) {
Map.Entry<LabelNode, BitSet> entry = it.next();
LabelNode lab = entry.getKey();
BitSet sub = entry.getValue();
int index = instructions.indexOf(lab);
markSubroutineWalk(sub, index, anyvisited);
}
}
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:23,代码来源:JSRInlinerAdapter.java
示例2: markSubroutines
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
/**
* Walks the method and determines which internal subroutine(s), if any,
* each instruction is a method of.
*/
private void markSubroutines() {
BitSet anyvisited = new BitSet();
// First walk the main subroutine and find all those instructions which
// can be reached without invoking any JSR at all
markSubroutineWalk(mainSubroutine, 0, anyvisited);
// Go through the head of each subroutine and find any nodes reachable
// to that subroutine without following any JSR links.
for (Iterator<Map.Entry<LabelNode,BitSet>> it = subroutineHeads.entrySet().iterator(); it.hasNext();)
{
Map.Entry<LabelNode,BitSet> entry = it.next();
LabelNode lab = entry.getKey();
BitSet sub = entry.getValue();
int index = instructions.indexOf(lab);
markSubroutineWalk(sub, index, anyvisited);
}
}
开发者ID:wro4j,项目名称:nashorn-backport,代码行数:23,代码来源:JSRInlinerAdapter.java
示例3: visitJumpInsn
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
/**
* Detects a JSR instruction and sets a flag to indicate we will need to do
* inlining.
*/
@Override
public void visitJumpInsn(final int opcode, final Label lbl) {
super.visitJumpInsn(opcode, lbl);
LabelNode ln = ((JumpInsnNode) instructions.getLast()).label;
if (opcode == JSR && !subroutineHeads.containsKey(ln)) {
subroutineHeads.put(ln, new BitSet());
}
}
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:13,代码来源:JSRInlinerAdapter.java
示例4: Subroutine
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
Subroutine(final LabelNode start, final int maxLocals,
final JumpInsnNode caller) {
this.start = start;
this.access = new boolean[maxLocals];
this.callers = new ArrayList<JumpInsnNode>();
callers.add(caller);
}
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:8,代码来源:Subroutine.java
示例5: Subroutine
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
Subroutine(
final LabelNode start,
final int maxLocals,
final JumpInsnNode caller)
{
this.start = start;
this.access = new boolean[maxLocals];
this.callers = new ArrayList<JumpInsnNode>();
callers.add(caller);
}
开发者ID:wro4j,项目名称:nashorn-backport,代码行数:11,代码来源:Subroutine.java
示例6: entrySet
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
@Override
public Set<Map.Entry<LabelNode, LabelNode>> entrySet() {
return null;
}
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:5,代码来源:JSRInlinerAdapter.java
示例7: get
import jdk.internal.org.objectweb.asm.tree.LabelNode; //导入依赖的package包/类
@Override
public LabelNode get(final Object o) {
return gotoLabel((LabelNode) o);
}
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:5,代码来源:JSRInlinerAdapter.java
注:本文中的jdk.internal.org.objectweb.asm.tree.LabelNode类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论