并发编程-基础篇(十二)之概念

  1. 什么是并发?什么是并行?并发和并行的区别是什么?
    1. 并发是指同一个时间段多个任务同时都在执行,并且都没有执行结束
    2. 并行是指在单位时间内多个任务同时都在执行
    3. 区别:时间段不同.并发强调的是在同一时间段,并行强调单位时间段
  2. 为什么要进行多线程并发编程?
    1. 为了减少上下文切换带来的开销
    2. 为了处理海量数据和请求的要求
  3. 什么是线程安全问题?
    1. 当多个线程同时读写一个共享资源并且没有任何的同步措施时,导致出现脏数据和其他不可预见的结果
  4. 多个线程共享了资源,当他们都去访问这个这个共享资源就会产生线程安全问题呢?
    1. 不是.如果多个线程只是 读取这个共享变量,那么不会发生线程安全问题.只有当共享变量发生修改时,才会产生共享变量线程安全问题
  5. java内存模型规定,将所有变量都存放在主内存中,将线程当变量使用,会把主内存里面的变量复制到自己的工作空间或者叫作工作内存,线程读写变量操作的是自己工作内存变量
  6. synchronized 是用来解决内存可见性问题,synchronized 块是把在synchronized 块内对共享变量的修改刷新到主内存,同时synchronized 经常被用来实现原子性操作,synchronized 关键字会引起线程上下文切换带来调度开销
  7. volatile也是用来解决内存可见性问题,volatile关键字和sychronized关键字的区别?
    1. volatile不会带来上下文切换开销,sychronized会
    2. 当程序写入了volatile变量值的时候就等价于线程退出synchronized,读取volatile变量值时就相当于进入同步代码块
    3. volatile是直接操作主内存的共享变量,synchronized是操作本地线程的共享变量副本,在退出synchronized的时候才同步更新主内存的共享变量.
    4. volatile不保证原子性,只保证共享变量可见性,synchronized保证原子性也保证共享变量可见性
    5. volatile能避免重排序和内存可见性问题

你可能感兴趣的:(多线程)