方法多个返回值书写方式

有时候我们调用方法的时候返回值有可能不止1个,比如说我们返回name = "张三" age = 20这两个值,那么这个时候方法的返回值怎么写呢。在Scala和python中都有Tuple使用,在java中我们怎么办。很容易我们就想到了一个方式:可以构造一个User类来封装这两个属性。 
但是如果返回的两个值并没有任何关联关系,或者说每一个方法返回的参数都不同,那么我们就得为每一个方法的返回类型去创建对应的类来取包装,或许还有其他的解决方式,比如说返回一个map,返回一个List,返回一个array都可以。 
使用map作为返回值的话调用方在不清楚map中具体有什么内容的时候需要去遍历keySet或entrySet,而list和array也是同样的问题,不知道哪一个参数存放在哪里。下面就是解决方法,

org.apache.commons.lang3.tuple下的
public Triple<Boolean, Double, Integer> getGlobalOverwriteKBp(final SimStdPlan simStdPlan) {
        final boolean overwriteKAndBP = StdPlanTypeBpKEnum.COVER.getCode().equals(simStdPlan.getOverwriteKBp());
        Double k = Constants.DEFAULT_K;
        Integer bp = Constants.DEFAULT_BP;
        // 目前暂时获取全局覆盖
        if (overwriteKAndBP) {
            final SimSchemaGlobalParams globalParams = simSchemaGlobalParamsGateway.selectOneByTargetId(simStdPlan.getId());
            if (globalParams == null) {
                k = null;
                bp = null;
            } else {
                if (Objects.nonNull(globalParams.getSl())) {
                    k = globalParams.getSl().doubleValue();
                }
                if (Objects.nonNull(globalParams.getBp())) {
                    bp = globalParams.getBp();
                }
            }
        }
        return ImmutableTriple.of(overwriteKAndBP, k, bp);
    }

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想在函数中返回一个值,并使用多线程执行该函数,可以使用`concurrent.futures`模块中的`ThreadPoolExecutor`来实现。下面是一个示例: ```python import concurrent.futures def func1(): return "Function 1" def func2(): return "Function 2" def func3(): return "Function 3" # 创建线程池 with concurrent.futures.ThreadPoolExecutor() as executor: # 提交要执行的函数,并获取返回值的Future对象 future1 = executor.submit(func1) future2 = executor.submit(func2) future3 = executor.submit(func3) # 获取函数执行结果 result1 = future1.result() result2 = future2.result() result3 = future3.result() print(result1) print(result2) print(result3) ``` 在上述示例中,我们定义了三个函数 `func1()`、`func2()` 和 `func3()`,它们分别返回不同的字符串。使用`ThreadPoolExecutor`创建一个线程池,然后使用`executor.submit()`方法提交要执行的函数,并获取返回值的`Future`对象。通过调用`result()`方法来获取函数的执行结果。 请注意,`submit()`方法是非阻塞的,可以立即返回一个`Future`对象,表示正在执行的函数。通过调用`result()`方法可以阻塞等待该函数执行完成,并返回函数的返回值。 在这个示例中,我们使用了`with`语句来自动管理线程池资源的释放,不需要显式地调用`executor.shutdown()`方法。 最后,我们打印出三个函数的执行结果。根据函数的具体逻辑,你可以根据需要对返回值进行进一步处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值