Java 代码优化:使用构造函数和使用一个个set...

在对Java代码进行优化的时候,想方设法的要提高整体的效率,使用JProfiler看代码的时间占比,然后,看看哪些部分是可以优化的,减少运行时间的。下面有这么几个方向。

https://blog.csdn.net/qq_27093465/article/details/92763548

1,能使用构造函数一步到位的,就尽量使用构造函数,而不是使用一个个setter函数

2,能使用数组的,就使用数组。替代list,数组是真的快。

3,for循环的时候,使用for i循环针对list接口的集合,不使用for each 循环。for i循环的时候,把length的值提到for循环之外。

4,有些变量能提出来的,取一次,多次使用。不要频繁的get。即使是一个简单的int值。

5,要是能使用内部类的话,可以使用内部类,这样可以省去getter,setter方法的使用。

6,json的序列化和反序列化,不要说理论上是fastjson快,就使用fastjson,因为针对数据结构的简单复杂程度,来选择使用什么去序列化和反序列化,要实际测试之后,再说话。不能直接照搬理论,因为有时候Gson真的很快。

下面对这个构造和set的效率对比

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个基本的Redis分布式锁的Java实现。它包括获取锁、释放锁、自动续期、可重入等功能。可以根据具体需求进行修改和优化。 ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.params.SetParams; public class RedisDistributedLock { private final Jedis jedis; private final String lockKey; private final String lockValue; private final int expireTime; private final long retryInterval; private final int maxRetryTimes; private final ThreadLocal<Integer> reentrantCount; public RedisDistributedLock(Jedis jedis, String lockKey, String lockValue, int expireTime, long retryInterval, int maxRetryTimes) { this.jedis = jedis; this.lockKey = lockKey; this.lockValue = lockValue; this.expireTime = expireTime; this.retryInterval = retryInterval; this.maxRetryTimes = maxRetryTimes; this.reentrantCount = new ThreadLocal<>(); this.reentrantCount.set(0); } /** * 获取锁 * * @return true:获取锁成功;false:获取锁失败 */ public boolean lock() throws InterruptedException { int retryTimes = 0; while (retryTimes < maxRetryTimes) { SetParams params = new SetParams(); params.nx().ex(expireTime); String result = jedis.set(lockKey, lockValue, params); if ("OK".equals(result)) { return true; } retryTimes++; Thread.sleep(retryInterval); } return false; } /** * 释放锁 */ public void unlock() { int count = reentrantCount.get(); if (count > 0) { reentrantCount.set(count - 1); return; } if (lockValue.equals(jedis.get(lockKey))) { jedis.del(lockKey); } } /** * 自动续期 */ public void renew() { jedis.expire(lockKey, expireTime); } /** * 可重入锁 * * @return true:获取锁成功;false:获取锁失败 */ public boolean reentrantLock() { int count = reentrantCount.get(); if (count > 0) { reentrantCount.set(count + 1); return true; } if (lockValue.equals(jedis.get(lockKey))) { reentrantCount.set(1); return true; } return false; } } ``` 使用示例: ```java public class Main { public static void main(String[] args) throws InterruptedException { Jedis jedis = new Jedis("localhost", 6379); RedisDistributedLock lock = new RedisDistributedLock(jedis, "my_lock", "my_value", 10, 1000, 3); try { if (lock.lock()) { // 获取锁成功,执行业务逻辑 System.out.println("Got the lock, do something..."); Thread.sleep(5000); } else { // 获取锁失败,处理异常情况 System.out.println("Failed to get the lock"); } } finally { lock.unlock(); } } } ``` 注意事项: - RedisDistributedLock类的构造函数需要传入Jedis对象,因此需要先导入jedis依赖。 - 为了防止误删其他线程的锁,lockValue应该是一个随机生成的字符串,确保每个线程都有自己的标识。 - 自动续期和可重入锁需要在业务逻辑中显式调用,否则会因为过期或者重入次数不匹配而导致锁失效。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值