并发知识汇总

http://blog.csdn.net/lmj623565791/article/details/26626391

猪厂面试(Java后台开发)

  • i++的并发问题在栈中如何改变
  • atomicInteger的具体实现原理(直接说了句硬件实现保证变量的原子操作,其他的关键点没说出来,没复习)
  • threadlocal源码实现
  • 多线程共享数据的多种方式,除了共享变量
  • 为什么hashtable用了synchronized,concurrentHashMap用的是ReentrantLcok
  • 线程有序执行的几种方法,守护线程之前的线程死循环的条件下守护线程如何结束
  • 读写锁(会吗?不太了解,只知道CopyAndWriteArrayList)
  • 两个线程操作一个变量i,一个从1-50自加,一个从51-100自加,最终结果输出给main线程,保证main的结果准确,结果一定是两个线程变量的准确值相加(如何保证线程安全)
  • 生产者消费者模型写代码(不能用blockingqueue)
  • java反射的过程,C++有反射吗?为什么没有?
  • 抽奖,如何保证10小时内发出十个奖品保证公平性(不能将奖品在很短的时间间隔全部发出)
  • hashmap的entry太长怎么处理
  • gc的几种方法原理,脱离jvm应用,引用计数方式的优缺点,GCRoot的优缺点,在哪种条件下引用计数能比GCRoot发挥更好的效果?
  • 写一段代码,给出一个用数组实现的队列,保证队列在满的条件下依旧能够push,在push之前pop队头元素(感觉是考察线程安全的问题,一直在跟面试官确认线程安全和队列可有的数据结构)
  • Tcp的连接过程,加解密算法的简单逻辑,常有的MITM能干啥?CA的详细验证过程

i++的并发问题,在栈中如何改变##

通过源码的字节码观察数据移动过程,使用javap -c class文件名查看对应的class文件内容
JVM指令集:http://blog.csdn.net/lm2302293/article/details/6713147

public class Test {    
    public static void main(String[] args) {
        int i = 0;        
        i = i++;        
        System.out.println(i);
   }
}

Class字节码文件分析
Compiled from "Test.java"
public class Test {
  public Test();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."":()V
       4: return

  public static void main(java.lang.String[]);
    Code:
       0: iconst_0    // 将常量0放入栈中
       1: istore_1    // 将栈中的0存入局部变量1中
       2: iload_1     // 将局部变量1的值(也就是0)存入栈中
       3: iinc          1, 1 //对局部变量1中的值自加(加后为1)
       6: istore_1   //重新将栈中的0存入局部变量1的值中,此时局部变量1的值又变回0
       7: getstatic     #2                  // Field java/lang/System.out:Ljava/io/PrintStream;
      10: iload_1   // 将局部变量1的值写回栈中,此时为0,因此i依旧为0;
      11: invokevirtual #3                  // Method java/io/PrintStream.println:(I)V
      14: return
}

你可能感兴趣的:(并发知识汇总)