Module jdk.jdi

Interface MonitorContendedEnterRequest

所有超级接口:
EventRequest, Mirror

public interface MonitorContendedEnterRequest extends EventRequest
请求通知目标VM中尝试进入另一个线程已经获取的监视器的线程。当启用的MonitorContededEnterRequest满足时,将在EventQueue上放置一个包含MonitorContendedEnterEvent的事件集。现有的MonitorContendedEnterEvents集合由EventRequestManager管理。
自1.6起:
参见:
  • Method Details

    • addThreadFilter

      void addThreadFilter(ThreadReference thread)
      限制此请求生成的事件,使其在给定线程中。
      参数:
      thread - 要过滤的线程。
      抛出:
      InvalidRequestStateException - 如果此请求当前已启用或已删除。只能向已禁用的请求添加过滤器。
    • addClassFilter

      void addClassFilter(ReferenceType refType)
      限制此请求生成的事件,使其方法在给定的引用类型或其任何子类型中。将为可以安全转换为给定引用类型的引用类型中的任何位置生成事件。
      参数:
      refType - 要过滤的引用类型。
      抛出:
      InvalidRequestStateException - 如果此请求当前已启用或已删除。只能向已禁用的请求添加过滤器。
    • addClassFilter

      void addClassFilter(String classPattern)
      限制此请求生成的事件,使其方法在与此受限制的正则表达式匹配的类中。正则表达式仅限于精确匹配和以'*'开头或以'*'结尾的模式;例如,"*.Foo"或"java.*"。
      参数:
      classPattern - 要过滤的模式字符串。
      抛出:
      InvalidRequestStateException - 如果此请求当前已启用或已删除。只能向已禁用的请求添加过滤器。
    • addClassExclusionFilter

      void addClassExclusionFilter(String classPattern)
      限制此请求生成的事件,使其方法不在与此受限制的正则表达式匹配的类中,例如"java.*"或"*.Foo"。
      参数:
      classPattern - 要过滤的模式字符串。
      抛出:
      InvalidRequestStateException - 如果此请求当前已启用或已删除。只能向已禁用的请求添加过滤器。
    • addInstanceFilter

      void addInstanceFilter(ObjectReference instance)
      限制此请求生成的事件,使其当前执行的实例("this")是指定的对象。

      并非所有目标都支持此操作。使用VirtualMachine.canUseInstanceFilters()来确定是否支持该操作。

      参数:
      instance - 必须是当前实例才能通过此过滤器的对象。
      抛出:
      UnsupportedOperationException - 如果目标虚拟机不支持此操作。
      InvalidRequestStateException - 如果此请求当前已启用或已删除。只能向已禁用的请求添加过滤器。