多线程之用锁随便写写

try {

Lock lock = new ReentrantLock();
            lock.lock();
            List<BizShipmentManifest> fests= new ArrayList<BizShipmentManifest>();
            BizCourierAccount courierAccount = ValidateUtil.validateAndFindById(param.getCourierAccountId(),
                    bizCourierAccountProvider);
            Long courierId = courierAccount.getCourier().getId();
            CourierAccCredential courierConfigure = courierConfigContainer.getCourierAccCred(courierAccount.getId());
            CourierConfigure courierAccCredential = courierConfigContainer.getCourierConfigure(courierId);
            @SuppressWarnings("unchecked")
            ICourierApi<CourierAccCredential, CourierConfigure> courierApi = courierConfigContainer
                    .getCourierApiByCourierId(courierId);
    
            BaseResponse<List<ShipmentManifest>> response = courierApi.commitShipments(courierAccCredential, courierConfigure,
                    param.getAddress(),param.getCourierAccountId());
            if (response != null && response.getData() != null && response.getData().size()>0)
            {
                List<ShipmentManifest> shipmentManifests = response.getData();
                    for(ShipmentManifest shipmentManifest:shipmentManifests) {
                        logger.info("commitShipments courierAccountId={} return data:{}", courierAccount.getId(), JSON.toJSONString(shipmentManifest));
                        SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");
                        String fileName = String.format("%s_%s_%s.pdf", courierAccount.getCourier().getCourierCode(),
                                param.getCourierAccountId(), format.format(new Date()));
                        String filePath = String.format("/home/tms/manifest/%s", fileName);
                        // 保存文件
                        FileUtil.createFile(filePath, shipmentManifest.getContent());
                        BizShipmentManifest manifest = new BizShipmentManifest();
                        manifest.setCourierAccountId(param.getCourierAccountId());
                        manifest.setCourierCode(courierAccount.getCourier().getCourierCode());
                        manifest.setFilePath(filePath);
                        fests.add(manifest);
                        bizShipmentManifestProvider.createModelTxNew(manifest, o);
                        logger.info("Get Out commitShipments,fileName={} ", filePath);
                        Thread.sleep(5000);
                    }
            }
            return fests.size()<1?null:fests;
        }catch(Exception e ){
            logger.info(e.getMessage());
             throw new ShipmentApiException(e.getMessage());
        }finally {
            logger.info("Get Out commitShipments, the courieraccountId is {}!", param.getCourierAccountId());
            lock.unlock();
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值