天天看点

jacoco core.runtime包源码分析1 IExecutionDataAccessorGenerator

1 IExecutionDataAccessorGenerator

jacoco core.runtime包源码分析1 IExecutionDataAccessorGenerator

被 instrument 的类需要一段代码,该代码从运行时获取 boolean[]实例。

该机制是针对于运行时的,因此由该接口抽象。 实现由 IRuntime 实现提供,并由 instrumentation process过程使用。

唯一方法

/**
     * 此方法生成获得具有给定id的类的coverage数据结构所需的字节码。 通常,instrumentation 过程会将此代码嵌入到在类初始化时调用的方法中。甚至可以在目标VM外部随时调用此方法。
     *
     * 生成的代码必须将 boolean[] 实例推入操作数栈。 除此结果对象外,生成的代码不得对嵌入方法或类的结构进行任何假设。 生成的代码不得使用或分配局部变量。
     *
     * @param classid
     * @param classname
     *            VM class name
     * @param probecount
     *            probe count for this class
     * @param mv
     *            code output
     * @return additional stack size required by the implementation, including
     *         the instance pushed to the stack
     */
    int generateDataAccessor(long classid, String classname, int probecount,
            MethodVisitor mv);      

IRuntime 实现类

package org.jacoco.core.runtime;

/**
 * 此接口表示一种特定的机制,用于在运行时收集目标VM中的执行信息。
 */
public interface IRuntime extends IExecutionDataAccessorGenerator {

    /**
     * start coverage runtime. 
     * This method MUST be called before any class instrumented for this runtime is loaded.
     * 必须在加载为此运行时检测到的任何类之前调用此方法。
     *
     * @param data
     *            the execution data for this runtime
     * @throws Exception
     *             any internal problem during startup
     */
    void startup(RuntimeData data) throws Exception;

    /**
     * Allows the coverage runtime to cleanup internals. This class should be
     * called when classes instrumented for this runtime are not used any more.
     * 允许coverage运行时清理内部。 当不再使用为此运行时检测的类时,应调用该类。
     */
    void shutdown();

}
      

继续阅读