一些java的demo

     //1. false
        System.out.println(Integer.parseInt("01")>10);
        //2. abcdefghijklmnopqrstuvwxyz
        System.out.println("ABCDEFGHIJKLMNOPQRSTUVWXYZ".toLowerCase(Locale.ENGLISH));
        //3. true
        String regex = "CCNB-APPROVAL-[0-9]{8}-[0-9]{1,5}\\.ok";
        String name = "CCNB-APPROVAL-20150306-01.ok";
        System.out.println(name.matches(regex));
        //4.  false
        System.out.println(!true);
        //5.  a
        System.out.println("abc".substring(0,1));
        //6.  null
        System.out.println("null");
        //编译不通过
        System.out.println(null);

 

转载于:https://www.cnblogs.com/scorates/p/10491930.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用看门狗为Redis分布式锁续约的Java demo: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.params.SetParams; public class RedisLock { private Jedis jedis; private String key; private int timeout; private Thread watchDogThread; private boolean locked; public RedisLock(Jedis jedis, String key, int timeout) { this.jedis = jedis; this.key = key; this.timeout = timeout; this.watchDogThread = null; this.locked = false; } public void acquire() throws InterruptedException { /* * 获取分布式锁,如果获取成功,则启动看门狗线程续约 */ while (!locked) { // 尝试获取锁 long lockValue = System.currentTimeMillis() + timeout + 1; SetParams params = SetParams.setParams().nx().ex(timeout); String result = jedis.set(key, String.valueOf(lockValue), params); if ("OK".equals(result)) { // 获取锁成功,启动看门狗线程续约 locked = true; watchDogThread = new Thread(this::watchDog); watchDogThread.start(); } else { // 获取锁失败,等待一段时间后重试 Thread.sleep(100); } } } public void release() { /* * 释放分布式锁,同时停止看门狗线程 */ if (locked) { locked = false; jedis.del(key); watchDogThread.interrupt(); } } public void renew() { /* * 续约,更新锁的过期时间 */ if (locked) { long lockValue = System.currentTimeMillis() + timeout + 1; jedis.set(key, String.valueOf(lockValue), "XX", "EX", timeout); } } public void watchDog() { /* * 看门狗线程,定期续约 */ while (locked) { try { Thread.sleep(timeout / 2); renew(); } catch (InterruptedException e) { // 线程被中断,停止看门狗线程 break; } } } } ``` 在这个demo中,我们定义了一个RedisLock类,其中包含了获取锁、释放锁、续约等方法。在获取锁的时候,如果获取成功,则会启动一个看门狗线程,在锁的过期时间内定期向Redis发送续约请求。在释放锁的时候,会停止看门狗线程。在程序运行过程中,我们创建了一个RedisLock对象,并使用该对象获取分布式锁,然后等待一段时间后释放锁。 需要注意的是,在Java中,我们使用了Lambda表达式来创建看门狗线程。如果你的Java版本不支持Lambda表达式,可以将watchDog方法写成一个普通的方法,然后创建一个新的类来实现Runnable接口。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值