文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

大数据线程高级部分内容有哪些

2023-06-02 05:21

关注

本篇内容介绍了“大数据线程高级部分内容有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

首先讲一下线程的生命周期

> 对于一个线程, 在被创建后, 不是立即就进入到了运行状态, 也不是一直处于运行状态, 在线程的声明周期中, 一个线程会在多种状态之间进行切换

>

>  

>

> new : 新生状态, 线程被实例化, 但是还没有开始执行(start)

>

> runnable: 就绪状态, 已经执行过start, 线程已经启动了, 只是没有抢到CPU时间片

>

> running: 运行状态, 抢到了CPU时间片

>

> blocked: 阻塞状态, 线程执行的过程中, 遇到一些特殊情况, 会进入阻塞状态. 阻塞中的线程, 是不能参数时间片的抢夺的 (不能被线程调度器调度)

>

> dead: 死亡状态, 线程终止

>

>  正常死亡 : run方法中的代码执行结束

>

>  非正常死亡 : 强制使用stop方法停止这个线程

#### 临界资源问题

> 由于线程之间是资源共享的。如果有多个线程,同时对一个数据进行操作,此时这个数据会出现问题。

> 如果有一个线程在访问一个临界资源,在访问之前,先对这个资源“上锁”,此时如果有其他的线程也需要访问这个临界资源,需要先查这个资源有没有被上锁,如果没有被上锁,此时这个线程可以访问这个资源;如果上锁了,则此时这个线程进入阻塞状态,等待解锁。

####同步代码段

> ```java

> // 同步代码段

> // 小括号:就是锁

> // 大括号:同步代码段,一般情况下,写需要对临界资源进行的操作

> synchronized () {

>   

> }

> // 关于同步锁:可以分成两种:对象锁、类锁

> //

> ```

>

####同步方法

> ```java

> // 使用synchronized关键字修饰的方法就是同步方法

> // 将一个方法中所有的代码进行一个同步

> // 相当于将一个方法中所有的代码都放到一个synchronized代码段中

> // 同步方法的锁:

> // 1. 如果这个方法是一个非静态方法:锁是this

> // 2. 如果这个方法是一个静态方法:锁是类锁(当前类.class)

> private synchronized void sellTicket() {

> }

> ```

>

#### lock与unlock

> 就是一个类RenntrantLock

#### 线程死锁(了解)

在解决临界资源问题的时候,我们引入了一个"锁"的概念。我们可以用锁对一个资源进行保护。实际,在多线程的环境下,有可能会出现一种情况:

> 假设有A和B两个线程,其中线程A持有锁标记a,线程B持有锁标记b,而此时,线程A等待锁标记b的释放,线程B等待锁标记a的释放。这种情况,叫做  **死锁**

#### 生产者消费者设计模式

> wait() 、notify() 、notifyAll()

>

> wait(): 等待。使得当前的线程释放锁标记,进入等待队列。可以使当前的线程进入阻塞状态。

>

> notify(): 唤醒,唤醒等待队列中的一个线程。

>

> notifyAll(): 唤醒,唤醒等待队列中所有的线程。

> wait和sleep的区别:

>

> 1. 两个方法都可以使一个线程进入阻塞。

> 2. 区别:wait方法会释放锁标记,sleep则不会释放锁标记。

####懒汉式单例设计模式中的线程安全问题

#### 线程池

> ThreadPoolExecutor类是线程池最核心的类。这个类的构造方法中的几个参数:

>

> int corePoolSize: 核心线程数量。核心池大小。

>

> int maxmiunPoolSize: 线程池中最多的线程数量。

>

> long keepAliveTime: 核心线程之外的临时线程,能存活的时间。(从这个线程空闲的时候开始算)

>

> TimeUnit unit: 上面的时间单位

>

>  NANOSECONDS: 纳秒

>

>  MICROSECONDS: 微秒

>

>  MILLISEONDS: 毫秒

>

>  SECONDS: 秒

>

>  MINUTES: 分

>

>  HOURS: 时

>

>  DAYS: 天

>

> BlockingQueue<Runnable> workQueue: 等待队列

>

>  ArrayBlockingQueue

>

>  LinkedBlockingQueue

>

>   SynchronousQueue

>

> RejectedExecutionHandler handler:拒绝访问策略

“大数据线程高级部分内容有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯