當前位置: 首頁>>代碼示例>>Java>>正文


Java ReflectionUtils類代碼示例

本文整理匯總了Java中org.apache.bookkeeper.util.ReflectionUtils的典型用法代碼示例。如果您正苦於以下問題:Java ReflectionUtils類的具體用法?Java ReflectionUtils怎麽用?Java ReflectionUtils使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ReflectionUtils類屬於org.apache.bookkeeper.util包,在下文中一共展示了ReflectionUtils類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
public static void main(String args[]) {
    int rc = -1;
    if (args.length <= 0) {
        System.err.println("No tool to run.");
        System.err.println("");
        System.err.println("Usage : Tool <tool_class_name> <options>");
        System.exit(-1);
    }
    String toolClass = args[0];
    try {
        Tool tool = ReflectionUtils.newInstance(toolClass, Tool.class);
        String[] newArgs = new String[args.length - 1];
        System.arraycopy(args, 1, newArgs, 0, newArgs.length);
        rc = tool.run(newArgs);
    } catch (Throwable t) {
        System.err.println("Fail to run tool " + toolClass + " : ");
        t.printStackTrace();
    }
    System.exit(rc);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:21,代碼來源:Tool.java

示例2: createService

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
private DistributedLogServiceImpl createService(
        ServerConfiguration serverConf,
        DistributedLogConfiguration dlConf,
        CountDownLatch latch) throws Exception {
    // Build the stream partition converter
    StreamPartitionConverter converter;
    try {
        converter = ReflectionUtils.newInstance(serverConf.getStreamPartitionConverterClass());
    } catch (ConfigurationException e) {
        logger.warn("Failed to load configured stream-to-partition converter. Fallback to use {}",
                IdentityStreamPartitionConverter.class.getName());
        converter = new IdentityStreamPartitionConverter();
    }
    return new DistributedLogServiceImpl(
            serverConf,
            dlConf,
            ConfUtils.getConstDynConf(dlConf),
            new NullStreamConfigProvider(),
            uri,
            converter,
            NullStatsLogger.INSTANCE,
            NullStatsLogger.INSTANCE,
            latch);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:25,代碼來源:TestDistributedLogService.java

示例3: getEnsemblePlacementDnsResolverClass

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
 * Get the DNS resolver class for bookkeeper ensemble placement.
 * <p>By default, {@link DNSResolverForRacks} will be used if
 * {@link #getRowAwareEnsemblePlacementEnabled()} is disabled and
 * {@link DNSResolverForRows} will be used if {@link #getRowAwareEnsemblePlacementEnabled()}
 * is enabled.
 *
 * @return dns resolver class for bookkeeper ensemble placement.
 * @throws ConfigurationException
 * @see #getRowAwareEnsemblePlacementEnabled()
 */
public Class<? extends DNSToSwitchMapping> getEnsemblePlacementDnsResolverClass()
        throws ConfigurationException {
    Class<? extends DNSToSwitchMapping> defaultResolverCls;
    if (getRowAwareEnsemblePlacementEnabled()) {
        defaultResolverCls = DNSResolverForRows.class;
    } else {
        defaultResolverCls = DNSResolverForRacks.class;
    }
    return ReflectionUtils.getClass(this, BKDL_ENSEMBLE_PLACEMENT_DNS_RESOLVER_CLASS,
            defaultResolverCls, DNSToSwitchMapping.class, defaultLoader);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:23,代碼來源:DistributedLogConfiguration.java

示例4: runTool

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
private static int runTool(String[] args) throws Exception {
    Tool tool = ReflectionUtils.newInstance(args[0], Tool.class);
    String[] newArgs = new String[args.length - 1];
    System.arraycopy(args, 1, newArgs, 0, newArgs.length);
    int rc = tool.run(newArgs);
    assertTrue(0 == rc);
    return rc;
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:9,代碼來源:TestDistributedLogTool.java

示例5: getStreamPartitionConverterClass

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
 * Get the stream partition converter class.
 *
 * @return the stream partition converter class.
 * @throws ConfigurationException
 */
public Class<? extends StreamPartitionConverter> getStreamPartitionConverterClass()
        throws ConfigurationException {
    return ReflectionUtils.getClass(
            this,
            SERVER_STREAM_PARTITION_CONVERTER_CLASS,
            IdentityStreamPartitionConverter.class,
            StreamPartitionConverter.class,
            defaultLoader);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:16,代碼來源:ServerConfiguration.java

示例6: runCmd

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
void runCmd(CommandLine cmdline) throws IOException {
    StatsProvider statsProvider = new NullStatsProvider();
    if (cmdline.hasOption("p")) {
        String providerClass = cmdline.getOptionValue("p");
        statsProvider = ReflectionUtils.newInstance(providerClass, StatsProvider.class);
    }
    StatsReceiver statsReceiver = NullStatsReceiver.get();

    final MonitorService monitorService = new MonitorService(
            getOptionalStringArg(cmdline, "u"),
            getOptionalStringArg(cmdline, "c"),
            getOptionalStringArg(cmdline, "s"),
            getOptionalIntegerArg(cmdline, "i"),
            getOptionalIntegerArg(cmdline, "d"),
            getOptionalStringArg(cmdline, "f"),
            getOptionalIntegerArg(cmdline, "n"),
            getOptionalIntegerArg(cmdline, "t"),
            getOptionalIntegerArg(cmdline, "hck"),
            getOptionalBooleanArg(cmdline, "hsci"),
            getOptionalBooleanArg(cmdline, "w"),
            statsReceiver,
            statsProvider);

    monitorService.runServer();

    Runtime.getRuntime().addShutdownHook(new Thread() {
        @Override
        public void run() {
            logger.info("Closing monitor service.");
            monitorService.close();
            logger.info("Closed monitor service.");
        }
    });
    try {
        monitorService.join();
    } catch (InterruptedException ie) {
        logger.warn("Interrupted when waiting monitor service to be finished : ", ie);
    }
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:40,代碼來源:MonitorServiceApp.java

示例7: parseCommandLine

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
protected void parseCommandLine(String[] args)
        throws Exception {
    BasicParser parser = new BasicParser();
    CommandLine cmdline = parser.parse(options, args);
    if (cmdline.hasOption("h")) {
        printUsage();
        System.exit(0);
    }
    if (cmdline.hasOption("u")) {
        this.uri = URI.create(cmdline.getOptionValue("u"));
    } else {
        printUsage();
        System.exit(0);
    }
    this.conf = new DistributedLogConfiguration();
    if (cmdline.hasOption("c")) {
        String configFile = cmdline.getOptionValue("c");
        this.conf.loadConf(new File(configFile).toURI().toURL());
    }
    if (cmdline.hasOption("p")) {
        statsProvider = ReflectionUtils.newInstance(cmdline.getOptionValue("p"), StatsProvider.class);
    } else {
        statsProvider = new NullStatsProvider();
    }
    if (cmdline.hasOption("s")) {
        this.streamName = cmdline.getOptionValue("s");
    } else {
        printUsage();
        System.exit(0);
    }
    parseCommandLine(cmdline);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:33,代碼來源:StreamBenchmark.java

示例8: main

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
    if (args.length <= 0) {
        System.err.println(USAGE);
        return;
    }
    String benchmarkClassName = args[0];
    StreamBenchmark benchmark = ReflectionUtils.newInstance(
            benchmarkClassName, StreamBenchmark.class);
    benchmark.run(args);
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:11,代碼來源:StreamBenchmark.java

示例9: BrokerStarter

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
BrokerStarter(String[] args) throws Exception{
    StarterArguments starterArguments = new StarterArguments();
    JCommander jcommander = new JCommander(starterArguments);
    jcommander.setProgramName("PulsarBrokerStarter");

    // parse args by JCommander
    jcommander.parse(args);
    if (starterArguments.help) {
        jcommander.usage();
        System.exit(-1);
    }

    // init broker config and pulsar service
    if (isBlank(starterArguments.brokerConfigFile)) {
        jcommander.usage();
        throw new IllegalArgumentException("Need to specify a configuration file for broker");
    } else {
        brokerConfig = loadConfig(starterArguments.brokerConfigFile);
        pulsarService = new PulsarService(brokerConfig);
    }

    // if no argument to run bookie in cmd line, read from pulsar config
    if (!argsContains(args, "-rb") && !argsContains(args, "--run-bookie")) {
        checkState(starterArguments.runBookie == false,
            "runBookie should be false if has no argument specified");
        starterArguments.runBookie = brokerConfig.isEnableRunBookieTogether();
    }
    if (!argsContains(args, "-ra") && !argsContains(args, "--run-bookie-autorecovery")) {
        checkState(starterArguments.runBookieAutoRecovery == false,
            "runBookieAutoRecovery should be false if has no argument specified");
        starterArguments.runBookieAutoRecovery = brokerConfig.isEnableRunBookieAutoRecoveryTogether();
    }

    if ((starterArguments.runBookie || starterArguments.runBookieAutoRecovery)
        && isBlank(starterArguments.bookieConfigFile)) {
        jcommander.usage();
        throw new IllegalArgumentException("No configuration file for Bookie");
    }

    // init stats provider
    if (starterArguments.runBookie || starterArguments.runBookieAutoRecovery) {
        checkState(isNotBlank(starterArguments.bookieConfigFile),
            "No configuration file for Bookie");
        bookieConfig = readBookieConfFile(starterArguments.bookieConfigFile);
        Class<? extends StatsProvider> statsProviderClass = bookieConfig.getStatsProviderClass();
        bookieStatsProvider = ReflectionUtils.newInstance(statsProviderClass);
    } else {
        bookieConfig = null;
        bookieStatsProvider = null;
    }

    // init bookie server
    if (starterArguments.runBookie) {
        checkNotNull(bookieConfig, "No ServerConfiguration for Bookie");
        checkNotNull(bookieStatsProvider, "No Stats Provider for Bookie");
        bookieServer = new BookieServer(bookieConfig, bookieStatsProvider.getStatsLogger(""));
    } else {
        bookieServer = null;
    }

    // init bookie AutorecoveryMain
    if (starterArguments.runBookieAutoRecovery) {
        checkNotNull(bookieConfig, "No ServerConfiguration for Bookie Autorecovery");
        autoRecoveryMain = new AutoRecoveryMain(bookieConfig);
    } else {
        autoRecoveryMain = null;
    }
}
 
開發者ID:apache,項目名稱:incubator-pulsar,代碼行數:69,代碼來源:PulsarBrokerStarter.java

示例10: getFeatureProviderClass

import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
 * Get feature provider class.
 *
 * @return feature provider class.
 * @throws ConfigurationException
 */
public Class<? extends FeatureProvider> getFeatureProviderClass()
        throws ConfigurationException {
    return ReflectionUtils.getClass(this, BKDL_FEATURE_PROVIDER_CLASS, DefaultFeatureProvider.class,
            FeatureProvider.class, FeatureProvider.class.getClassLoader());
}
 
開發者ID:twitter,項目名稱:distributedlog,代碼行數:12,代碼來源:DistributedLogConfiguration.java


注:本文中的org.apache.bookkeeper.util.ReflectionUtils類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。