可调用的Guice DI

问题描述 投票:0回答:2

我在并行环境中使用Guice时遇到了一个具体的问题。

我有一个runnable,它接受构造函数的参数。

class task implements Runnable{
String dbname="";
task(String dbname)
{
this.dbname=dbname
}
@
Inject
private ICacheService cacheService
public void run(){
//logic here

}
bind(ICacheService).to(CacheServiceImpl.class);


}

问题:如何实例化Task。

我不能使用ExecutorService.submit(新的,因为这将不是正确的方式,并违反guice的目的。)

java guice
2个回答
1
投票

我会创建一个创建任务的工厂,通过任务中的构造函数注入ICacheService并使用javax.inject.Provider

public class TaskFactory {

    private Provider<ICacheService> cacheServiceProvider;

    @Inject
    public TaskFactory(Provider<ICacheService> cacheServiceProvider) {
        this.cacheServiceProvider = cacheServiceProvider;
    }

    public task create(String dbname) {
        return new task(dbname, cacheServiceProvider.get());
    }
}


class task implements Runnable {

    private final String dbname;
    private final ICacheService cacheService;

    public task(String dbname, ICacheService cacheService) {
        this.dbname = dbname;
        this.cacheService = cacheService;
    }

    @Override
    public void run() {

    }
}

完成此操作后,我将注入TaskFactory,然后使用dbName调用create方法。

您也可以使用Guice的AssistedInject来做类似的事情。

顺便说一句,班级名称应以大写字母开头。


0
投票

经过一番谷歌搜索后,我找到了解决方案。捆绑:

public class DependecnyBinderModule extends AbstractModule {

    @Override
    protected void configure() {
        bind(CloudSync.class).to(AWSCloudSyncImpl.class);

        bind(IConfigurationPropertyInitializer.class).to(ConfigurationPropertyInitializerImpl.class);

        bind(ICloudClientProvider.class).to(CloudClientProvider.class);

        bind(IQueryConnection.class).to(QueryConnectionImpl.class);

        bind(IWorkSpaceDescriptorInitialization.class).to(WorkSpaceDescriptorInitialize.class);
        bind(ISubscribeQueue.class).to(SubScribeQueueImpl.class);

        bind(InitializeDataSource.class).to(InitializeDataSourceImpl.class);

        bind(InitiateQueueListening.class).to(InitiateQueueListeningImpl.class);

        bind(DataExtractor.class).to(DataExtractorImpl.class);

        bind(DataTransformer.class).in(Scopes.SINGLETON);
        bind(TaskDispatcher.class);
        **install(new FactoryModuleBuilder().implement(Runnable.class, MultiQueueConsumer.class).build(TaskCreatorFactory.class));**

    }

    @Provides
    @Singleton
    ThreadFactory providesThreadFactory() {
        return new ThreadFactoryBuilder().setDaemon(true).setNameFormat("RealTimeSync-%d")
                .setUncaughtExceptionHandler(new RealTimeSyncExceptionHandler()).build();
    }



}

您的任务调度程序将任务分派给Executor。

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadFactory;

import com.google.inject.Inject;

/**
 * @author marwaha
 *
 */
public class TaskDispatcher {
@Inject
private ThreadFactory factory;

@Inject

private RuunableFactory factory2;
    private ExecutorService executor;

    public void dispatch(String name) {
        if(executor==null) {
            executor=Executors.newFixedThreadPool(5, factory);
        }
        executor.submit(factory2.create(name));

    }

}

RunnableFactory

public interface RuunableFactory {

    Task create(String dbname);
}
© www.soinside.com 2019 - 2024. All rights reserved.