Java并发编程中的一些基本概念

简介: Java并发编程中的一些基本概念


进程的基本概念


进程是操作系统级别的概念,操作系统给程序分配的一定资源


线程的概念

线程是cpu调用的基本单位,每一个线程执行某一个进程代码的基本片段


特点

  • 进程是线程的容器,线程利用进程中的一些资源,完成预期指令,实现预期效果
  • 进程是操作系统级别,线程是cpu级别
  • 进程与进程之间是相互独立的,线程共享一个进程内的资源
  • 进程创建没有线程快


多线程的概念

是指在单个进程中运行多个线程


多线程下存在的缺点

  • 线程数量特别多,频繁的上下文切换会消耗资源
  • 具体业务中也不是很好的拆分
  • 线程安全问题,例如死锁


串行、并行、并发

  • 串行是一个接着一个
  • 并行是大家一起上
  • 并发是指在一个进程中频繁的线程切换,提高线程的使用率
    需要注意的是多核cpu中存在并行,而单核cpu中只有并发


同步、异步、阻塞、非阻塞

  • 首先当发生I/O操作的时候,存在两方的参与,分别是调用方和被调用方。
  • 阻塞与非阻塞是描述调用方的概念。根据调用方是否要一直等待调用的返回结果,如果是要那就是阻塞,如果不要那就是非阻塞
  • 同步与异步,是指被调用方的概念,如果被调用方在接到了关于自己的调用指令,立即做出相应并返回结果信息那就是同步,否则那就是异步。
  • 所以四者之间是描述对象的不同,之间没有必然的关系

使用一个例子说明:

舒一笑去用锅烧开水,水开后,不会主动通知你,但是水看之后就能直接看到,所以我需要在一旁一直等待水烧开,对于水来说那是同步的,我作为调用者那就是阻塞的,————————————————————————————同步阻塞

舒一笑去用锅烧开水,水开后,不会主动通知我,但是在烧水的时候我再写这篇博客,是不是去看看水开了吗,对于水而言还是同步的,而我作为调用者没有一直等待,那就是非阻塞————————————————————————同步飞阻塞

舒一笑用美的水壶烧水,水开前一直等着,对于水而言方式变了,开了就能跳掉,而我还是一直等————————异步阻塞

舒一笑用美的水壶烧水,水开前我去健身了,对于水而言方式变了,开了就能跳掉,而我做我自己的事情——————————异步非阻塞,感觉这个异步就是用了一个更加直观的方式去专门了效果不好的方式。


目录
相关文章
|
5天前
|
存储 缓存 监控
Java面试题:在Java中,对象何时可以被垃圾回收?编程中,如何更好地做好垃圾回收处理?
Java面试题:在Java中,对象何时可以被垃圾回收?编程中,如何更好地做好垃圾回收处理?
16 0
|
4天前
|
Java 测试技术 开发者
Java面试题:解释CountDownLatch, CyclicBarrier和Semaphore在并发编程中的使用
Java面试题:解释CountDownLatch, CyclicBarrier和Semaphore在并发编程中的使用
27 11
|
1天前
|
Java 调度 开发者
Java中的并发编程:从基础到高级
【7月更文挑战第14天】在Java的世界中,并发编程是提升应用性能和响应能力的关键。本文将带领读者从线程的基础概念出发,深入探讨Java内存模型,逐步过渡到高级并发工具类如Executors框架和并发集合,最后通过案例分析展示如何在实际开发中运用这些知识解决并发问题。文章旨在为初学者提供清晰的学习路径,同时为有经验的开发者提供深度参考。
11 4
|
1天前
|
安全 Java 开发者
Java并发编程中的线程安全性与性能优化
在Java编程中,处理并发问题是至关重要的。本文探讨了Java中线程安全性的概念及其在性能优化中的重要性。通过深入分析多线程环境下的共享资源访问问题,结合常见的并发控制手段和性能优化技巧,帮助开发者更好地理解和应对Java程序中的并发挑战。 【7月更文挑战第14天】
|
1天前
|
监控 Java API
Java并发编程之线程池深度解析
【7月更文挑战第14天】在Java并发编程领域,线程池是提升性能、管理资源的关键工具。本文将深入探讨线程池的核心概念、内部工作原理以及如何有效使用线程池来处理并发任务,旨在为读者提供一套完整的线程池使用和优化策略。
|
3天前
|
存储 安全 算法
深入理解Java并发编程:线程安全与性能优化
【5月更文挑战第72天】 在现代软件开发中,尤其是Java应用开发领域,并发编程是一个无法回避的重要话题。随着多核处理器的普及,合理利用并发机制对于提高软件性能、响应速度和资源利用率具有重要意义。本文旨在探讨Java并发编程的核心概念、线程安全的策略以及性能优化技巧,帮助开发者构建高效且可靠的并发应用。通过实例分析和理论阐述,我们将揭示在高并发环境下如何平衡线程安全与系统性能之间的关系,并提出一系列最佳实践方法。
|
5天前
|
监控 Java 调度
Java面试题:描述Java线程池的概念、用途及常见的线程池类型。介绍一下Java中的线程池有哪些优缺点
Java面试题:描述Java线程池的概念、用途及常见的线程池类型。介绍一下Java中的线程池有哪些优缺点
18 1
|
1天前
|
Java 开发者
Java并发编程中的锁机制与性能优化
【7月更文挑战第14天】本文深入探讨了Java中锁的概念、种类及其在并发编程中的应用,并分析了不同锁类型对程序性能的影响。通过实例展示了如何合理选择和使用锁来提升应用的性能,同时指出了锁使用过程中可能遇到的问题和调优策略。旨在为Java开发者提供锁机制的深入理解和性能优化的实用建议。
|
5天前
|
Java API
Java面试题:说明Lambda表达式在Java中的应用,以及函数式接口的概念和作用。
Java面试题:说明Lambda表达式在Java中的应用,以及函数式接口的概念和作用。
11 0
|
5天前
|
Java API
Java面试题:解释死锁的概念,给出避免死锁的常见策略。你能给我一个具体的例子吗?
Java面试题:解释死锁的概念,给出避免死锁的常见策略。你能给我一个具体的例子吗?
6 0