当前位置: 首页 > news >正文

企业网站建设的建议/成都百度网站排名优化

企业网站建设的建议,成都百度网站排名优化,怎样做自己的手机网站,WordPress限制文件夹文件数🔍 开发者资源导航 🔍🏷️ 博客主页: 个人主页📚 专栏订阅: JavaEE全栈专栏 Callable 我们知道在JAVA的线程中我们只能执行任务,而这个任务不能返回一个值,而Callable的出现就是为了…

在这里插入图片描述

🔍 开发者资源导航 🔍
🏷️ 博客主页: 个人主页
📚 专栏订阅: JavaEE全栈专栏

Callable

我们知道在JAVA的线程中我们只能执行任务,而这个任务不能返回一个值,而Callable的出现就是为了弥补这一缺陷。

Callable:定义一个带有返回值的任务, 并没有真的在执行,需要搭配Thread对象来使用。

Thread本身不提供获取结果的方法,需要凭FurureTask对象来得到结果,这么做是为了解耦合。

public static void main(String[] args) throws ExecutionException, InterruptedException {Callable<Integer> callable = new Callable<Integer>() {@Overridepublic Integer call() throws Exception {Integer res = 0;for (int i = 0; i < 10; i++) {res += i;}return res;}};FutureTask<Integer> futureTask = new FutureTask<>(callable);Thread thread = new Thread(futureTask);thread.start();System.out.println(futureTask.get());
}
//匿名写法
FutureTask<Integer> futureTask = new FutureTask<>(()->{Integer res = 0;for (int i = 0; i < 10; i++) {res += i;}return res;
});

get方法用于获取FutureTask的返回值,如果FutureTask没有运行完成get方法会产生阻塞,直到线程运行完毕,get拿到返回结果。

ReentrantLock (可重入锁)

通过lock()和unlock()方法加解锁,效率比synchronized低,远古时期用的较多。

如果要使用ReentrantLock进行加锁,可以通过此方式防止忘记解锁

locker.lock();
try {//代码逻辑
} finally {locker.unlock();
}

ReentrantLock和synchronized的区别:

  1. synchronized 是 关键字(内部实现是 JVM 内部通过 C++ 实现的),ReentrantLock 标准库的类(Java)。
  2. synchronized 通过代码块控制加锁解锁,ReentrantLock 需要 lock/unlock 方法,需要注意 unlock 不被调用的问题。
  3. ReentrantLock 除了提供 lock, unlock 之外,还提供了一个方法trylock(),这个方法不会产生阻塞,加锁成功返回true,失败返回false,可以由调用者决定接下来怎么做。
  4. ReentrantLock提供了公平锁的实现,默认是非公平,需要在创建的时候传入true。
  5. ReentrantLock搭配的等待通知机制是Condition类,相比于wait notify来说要更加强大灵活一些。

semaphore(信号量)

信号量表示的是“可用资源的个数”,申请一个资源,计数器就会+1,释放一个就会-1,如果为0,继续申请就会陷入阻塞等待。

//设置初始数量
Semaphore semaphore = new Semaphore(5);
//申请一个资源
semaphore.acquire();
//获取多少个资源可以申请
System.out.println(semaphore.availablePermits());
//释放一个资源
semaphore.release();
System.out.println(semaphore.availablePermits());

作用:

  1. 限制同时访问某资源的线程数(如接口限流、数据库连接池)。
  2. 管理有限的资源(如线程池、数据库连接池)。

特殊场景:
当初始值为1时,等价于“锁”。

Semaphore mutex = new Semaphore(1);  // 二进制信号量void criticalSection() throws InterruptedException {mutex.acquire();try {// 临界区代码(同一时间仅一个线程可进入)} finally {mutex.release();}
}

CountDownLatch

在使用多线程,经常把一个大任务拆分成多个子任务,可以提高程序的效率。

那么我们如何判定这个大任务已经完成了呢?Java引入了CountDownLatch类帮助我们判定。

  1. 在构造时传入参数,表示有多少个任务。
  2. 在每个任务完成时,调用一次countDown方法,当次数足够时,说明任务已经全部完成。
  3. 在主线程中调用await方法会等待任务全部完成。
public static void main(String[] args) throws InterruptedException {CountDownLatch countDownLatch = new CountDownLatch(10);//重写工厂类方法ThreadFactory threadFactory = new ThreadFactory() {private int cnt = 0;@Overridepublic Thread newThread(Runnable r) {Thread thread = new Thread(r, "Thread" + cnt);thread.setDaemon(true);return thread;}};//使用工厂类创建线程池ExecutorService executorService = Executors.newFixedThreadPool(1, threadFactory);//提交任务for (int i = 0; i < 10; i++) {int id = i;executorService.submit(()->{System.out.println("开始" + Thread.currentThread().getName() + id);try {Thread.sleep(100);} catch (InterruptedException e) {throw new RuntimeException(e);}System.out.println("结束" + Thread.currentThread().getName() + id);countDownLatch.countDown();});}//等待全部完成countDownLatch.await();System.out.println("全部结束了");
}

感谢各位的观看Thanks♪(・ω・)ノ,如果觉得满意的话留个关注再走吧。

http://www.lryc.cn/news/580792.html

相关文章:

  • 个人做医疗类网站违法?/宣传广告
  • 做网站做图电脑需要什么配置/百度官方电话24小时
  • 湖南网站建设seo优化/网络营销的主要方法
  • 深圳网站上线方案/网络推广专家
  • 云南城市建设官方网站/快速排名优化推广价格
  • 网站为什么要改版/网站建设在线建站
  • 鄂州做网站/一键制作网站
  • python如何创建网页/seo是干嘛的
  • 新郑做网站优化/关键词密度查询站长工具
  • 网站的推广方案有哪些/医疗器械龙头股
  • 网页传奇国度/seo搜索引擎优化总结报告
  • 捡个杀手做老婆 在哪个网站/营销策划公司 品牌策划公司
  • wordpress轻应用主机/seo关键词优化推广哪家好
  • 遵义公司建网站要多少费用/seo排名
  • 自己建网站写小说可行吗/win7优化教程
  • 安徽建设厅证书查询网网站/网络营销工具介绍
  • 做网站吧/快速开发网站的应用程序
  • 南昌网站建设 南昌做网站公司/学计算机哪个培训机构好
  • 小县城做婚礼网站/百度广告联盟怎么加入
  • 网站制作中心/超级软文网
  • 图片点击就能跳转网站怎么做的/天津百度seo
  • 教育平台/昆山优化外包
  • 企业网站seo数据/南京seo外包
  • 赌博网站程序架设/品牌策划公司排名
  • 一个虚拟空间可以做两个网站吗/附近电脑培训班零基础
  • 做乒乓球网站的图片大全/上海抖音seo公司
  • 怎么开发网站程序/轻松seo优化排名
  • 如何做复制别人的网站模版/怎么推广网站
  • 陕西企业营销型网站建设/常用的网络营销方法有哪些
  • 营销型网站建设的公司/google官方下载安装