java 并发学习笔记(一)

一、并行和并发有什么区别?

       并行是指两个或者多个事件在同一时刻发生;而并发是指两个或多个事件在同一时间间隔发生。

       并行是在不同实体上的多个事件,并发是在同一实体上的多个事件。

       在一台处理器上“同时”处理多个任务,在多台处理器上同时处理多个任务。如hadoop分布式集群

二、线程和进程的区别

       进程是程序运行和资源分配的基本单位,一个程序至少有一个进程,一个进程至少有一个线程,进程在执行过程中拥有独立的内存单元,而多个线程共享内存资源,减少切换次数,从而效率更高。线程是进程的一个实体,是cpu调度和分配的基本单位,是比程序更小的能独立运行的基本单位。同一进程中的多个线程之间可以并发执行。

三、守护线程是什么?

      守护线程(即 daemon thread)是个服务线程,准确的说就是服务其他的线程。

四、创建线程的几种方式?

      1、继承thread类创建线程

      2、实现Runnable接口实现线程

      3、通过Callable和Future 创建线程

      4、通过线程池创建线程

五、Runnable和callable 有什么区别?

      Runnable接口中的run()方法的返回值是void,它做的事情只是纯粹地去执行run()方法中的代码而已。

      Callable接口中的方法是有返回值的,是一个范型,和future futureTask配合可以用来异步执行的结果。

六、线程的几种状态?

      Thread源码中定义了六种状态:new(新建),runnable(可执行),blocked(阻塞),waiting(等待),time waiting (定时等待)和terminated(终止)。

      

七、sleep和wait的区别?

       1,这两个方法来自不同的类分别是Thread(自控)和Object(他控)
       2,最主要是sleep方法没有释放锁,而wait方法释放了锁,使得其他线程可以使用同步控制块或者方法。
       3,wait,notify和notifyAll只能在同步控制方法或者同步控制块里面使用,而sleep可以在
                任何地方使用
                
        4,sleep必须捕获异常,而wait,notify和notifyAll不需要捕获异常

  八、run()和start()方法的区别?

         1.run()称为线程体,start()是启动线程的方法。
         2.如果直接调用run()方法,就相当于调用一个普通函数而已。

  九、在java程序中怎么保证多线程的运行安全?

          1.原子性:提供互斥访问,同一时刻只能有一个线程对数据进行操作。(atomic、synchronized)

          2.可见性:一个线程对主内存的修改可以及时的被其他线程看到(synchronized,volatile)

          3.一个线程观察其他线程中的指令执行顺序,由于指令重排序,该观察结果一般杂乱无序(happens-before 原则)

  十、java线程同步的几种方法?

         1.使用Synchronized关键字

         2、wait和notify ;

         3、使用特殊域变量valatile

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值