Задержка выполнения шага Java - PullRequest
0 голосов
/ 06 февраля 2012

Я хочу знать, есть ли более простой способ выполнить Java-выполнение.

function(){
  command 1;   
  thread.sleep();
  command 2;
  thread.sleep();
  ... and soo on
}

Я хочу отложить каждый шаг в моей функции, есть ли лучший способ сделать это?

Ответы [ 4 ]

2 голосов
/ 06 февраля 2012

Вы могли бы использовать что-то вроде этого, но я не очень хорошая идея.Я согласен с DaveHowes , что другого простого способа сделать это не существует.

package main;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.List;

public class TempClass {
    public static void main(String[] args) throws ParseException, InterruptedException, InvocationTargetException, NoSuchMethodException, IllegalAccessException {
        new TempClass().function();
    }

    private void function() throws NoSuchMethodException, InterruptedException, InvocationTargetException, IllegalAccessException {
        final Class aClass = this.getClass();
        List<Method> methods = new ArrayList<Method>() {{
            add(aClass.getDeclaredMethod("command1"));
            add(aClass.getDeclaredMethod("command2"));
        }};
        for (Method method : methods) {
            method.setAccessible(true);
            method.invoke(this);
            Thread.sleep(1000);
        }
    }

    private void command1() {
        System.out.println("command1");
    }

    private void command2() {
        System.out.println("command2");
    }
}
1 голос
/ 06 февраля 2012

Вы можете поместить команды в структуру данных, такую ​​как List, и передать список методу, который выполняет команду и затем спит в течение некоторого периода времени.Возможно, немного более элегантно, но, конечно, не проще.

Вы также можете рассмотреть возможность добавления их в таймер, но, опять же, он более элегантен, но содержит довольно много оборудования без особого улучшения функциональности.

0 голосов
/ 09 февраля 2012

Тест скорости:

package test;

import net.sf.cglib.reflect.FastClass;
import net.sf.cglib.reflect.FastMethod;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;

public class Test {

    private static final long SLEEP = 0;
    private static final Object[] withoutParameters = new Object[0];

    public static void main(String[] args) throws NoSuchMethodException, InvocationTargetException, InterruptedException, IllegalAccessException {
        final Method[] methods = getMethods(Test.class, "command1", "command2");
        final FastMethod[] fastMethods = getFastMethods(Test.class, methods);
        final Test test = new Test();
        final int loop = 10* 1000 * 1000;

        long timeStamp = System.currentTimeMillis();
        for (int i = 0; i < loop; i++) {
            test.functionDirectCall();
        }
        System.out.println("DirectCall time:" + (System.currentTimeMillis() - timeStamp));

        timeStamp = System.currentTimeMillis();
        for (int i = 0; i < loop; i++) {
            test.functionMethod(methods);
        }
        System.out.println("Method time:" + (System.currentTimeMillis() - timeStamp));

        timeStamp = System.currentTimeMillis();
        for (int i = 0; i < loop; i++) {
            test.functionFastMethod(fastMethods);
        }
        System.out.println("FastMethod time:" + (System.currentTimeMillis() - timeStamp));
    }

    private void functionDirectCall() throws InterruptedException {
        this.command1();
        Thread.sleep(SLEEP);
        this.command2();
        Thread.sleep(SLEEP);
    }

    private void functionMethod(Method... methods) throws InvocationTargetException, IllegalAccessException, InterruptedException {
        for (Method method : methods) {
            method.invoke(this);
            Thread.sleep(SLEEP);
        }
    }

    private void functionFastMethod(FastMethod... fastMethods) throws InvocationTargetException, InterruptedException {
        for (FastMethod fastMethod : fastMethods) {
            fastMethod.invoke(this, withoutParameters);
            Thread.sleep(SLEEP);
        }
    }

    private static Method[] getMethods(final Class aClass, final String... methodNames) throws NoSuchMethodException {
        return new ArrayList<Method>() {{
            for (String methodName : methodNames) {
                final Method method = aClass.getDeclaredMethod(methodName);
                method.setAccessible(true);
                this.add(method);
            }
        }}.toArray(new Method[methodNames.length]);
    }

    private static FastMethod[] getFastMethods(final Class aClass, final Method... methods) {
        final FastClass fastClass = FastClass.create(aClass);
        return new ArrayList<FastMethod>() {{
            for (Method method : methods) {
                add(fastClass.getMethod(method));
            }
        }}.toArray(new FastMethod[methods.length]);
    }

    public void command1() throws InterruptedException {
        Thread.sleep(SLEEP);
    }

    public void command2() throws InterruptedException {
        Thread.sleep(SLEEP);
    }
}

Выход:

DirectCall time:17615
Method time:19051
FastMethod time:17952
0 голосов
/ 06 февраля 2012

Вы не говорите, почему вы хотите это сделать;может быть, есть лучший способ достичь конечной цели, чем добавление нескольких задержек к вашему коду.

Если бы это требовалось для больших частей приложения, я бы посмотрел на внешнее применение механизма задержки:

  • Если бы это было для отладки, я бы посмотрел на использование типа JPDA StepRequest .

  • В маловероятном случае, если вы захотите это в рабочем коде, я бы преобразовал целевой байт-код, используя что-то вроде ASM .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...