dk.clanie.actor.SecondTestActorImpl.java Source code

Java tutorial

Introduction

Here is the source code for dk.clanie.actor.SecondTestActorImpl.java

Source

/**
 * Copyright (C) 2011, Claus Nielsen, cn@cn-consult.dk
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 */
package dk.clanie.actor;

import java.util.concurrent.Future;

import org.joda.time.Instant;
import org.springframework.scheduling.annotation.AsyncResult;

/**
 * Test actor.
 * 
 * @author Claus Nielsen
 */
@Actor
public class SecondTestActorImpl implements SecondTestActor {

    @Override
    public Future<?> methodCalledByFirstActor(int arg) {
        process("methodCalledByFirstActor", arg);
        return new AsyncResult<Object>(null);
    }

    @Override
    public void voidMethod(int arg) {
        process("voidMethod", arg);
    }

    @Override
    public Future<?> methodReturningFuture(int arg) {
        process("methodReturningFuture", arg);
        return new AsyncResult<Object>(null);
    }

    @Override
    public Object methodReturningObject(int arg) {
        process("methodReturningObject", arg);
        return null;
    }

    private void process(String method, int arg) {
        Thread currentThread = Thread.currentThread();
        method = getClass().getSimpleName() + "." + method;
        System.out.println(new Instant() + ": " + method + "(" + arg + ") START in " + currentThread);
        try {
            Thread.sleep(ActorAspectTest.SLEEPTIME);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(new Instant() + ": " + method + "(" + arg + ") DONE in " + currentThread);
    }

    @Override
    public Object sync() {
        return null;
    }

}