Java 5并发包的加入,给Java的并发程序的开发带来了很多的好处,在此列举一些并发编程中应该掌握的一些基础知识片断,这些片断基本都是由一些问题组成,在片段中没有直接写出答案,由于可用来解决这些片段的方法还是很多的,因此只是提到了解决问题可选方案的关键字,如果有需要进一步了解的话,基本上google一下应该就能查出来了,不过就像之前有朋友说的,如果不是经常用的话,其实就算现在知道了也是会忘记的,这很正常,:),不过我更认为那是因为知其然而不知其所以然造成的,很多东西如果知道原理的话,基本上还是可以记得很长一段时间的。
片断一
在main中启动两个线程,例如:
Thread a=new Thread(){
public void run(){
System.out.println("Call A");
try{
Thread.sleep(1000);
}
catch(Exception e){
e.printStackTrace();
}
}
};
Thread b=new Thread(){
public void run(){
try{
Thread.sleep(500);
}
catch(Exception e){
e.printStackTrace();
}
System.out.println("Call B");
}
};
a.start();
b.start();
System.out.println("execute here");
在这样的方式下,执行时会出现什么样的效果;
怎么样才能保证字符串的打印顺序是:"Call B"-->"Call A"-->"execute here"呢?(提示:wait/notify、Semphore、Lock等)
在做到了上面打印顺序控制后,怎么样才能做到如果线程b执行了100毫秒还没执行完的话则直接继续线程a的执行呢?(提示:ExecutorServices、Future)
片段二
也是个控制顺序的问题,假设有如下一段代码:
for(int i=0;i<10;i++){
Thread thread=new Thread(){
public void run(){
...
}
};
thread.setName("Thread-"+i);
thread.start();
}
System.out.println("All Executed");
需要做到所有线程同时运行,而不是按照for的顺序一个一个启动,并且要求All Executed需要在所有线程都执行完毕后才打印,有什么办法做到呢?(提示:CountDownLatch等)
片段三
Map<String,Object> datas=new ConcurrentHashMap<String,Object>();
public Object get(String keyName){
Object data=null;
if(!datas.containsKey(keyName)){
data=createData(keyName);
datas.put(keyName,data);
}
else{
data=datas.get(keyName;)
}
return data;
}
上面这段代码在并发时会出什么问题呢,为什么?
如果有问题的话,应该怎么去解决呢?(提示:Synchronized、Lock、FutureTask等)
片段四
ThreadPoolExecutor executor=new ThreadPoolExecutor(10,100,60L,TimeUnit.SECONDS,new LinkedBlockingQueue<Runnable>(20),new ThreadPoolExecutor.AbortPolicy());
一个这样的线程池,当并发请求数为15时会是怎么个状况?(池的使用状况,例如活动线程数、队列中的数等)
当并发请求数为100的时候是什么状况?
当并发请求数为200的时候是什么状况?
当30秒内不再有请求时会怎么样?
当2分钟内没有请求时会怎么样?
如果换成以下方式初始化池又会怎么样呢:
ThreadPoolExecutor executor=new ThreadPoolExecutor(10,150,20L,TimeUnit.SECONDS,new SynchronousQueue<Runnable>(),new ThreadPoolExecutor.AbortPolicy());
片段五
怎么查看jvm中线程的执行状况?
ThreadFactory有什么用?
如果要捕捉线程中抛出的异常,可以怎么做呢?
如果TimerTask抛出运行时异常会不会影响到同一个Timer中其他的TimerTask的执行呢?
片段六
常见的一个例子:
private int count;
public synchronized int getNext(){
return count++;
}
在JDK5有什么别的方法来进行实现吗?
像JDK5中的AtomicInteger的incrementAndGet是怎么实现的呢?
如果这个count要按线程来独立管理,即每个线程有自己的一个count,要怎么做呢?
暂时就列这些了,后面再继续,:)。
分享到:
相关推荐
java并发编程pdf文档第二部分:Java并发编程实战.pdf、Java多线程编程核心技术.pdf、实战Java高并发程序设计.pdf
JAVA并发编程艺术 高清pdf : 1.并发变成的挑战 2. java并发机制的底层实现原理 3. java 内存模型 4. java并发编程基础 5.java中的锁。。。。。。。
java并发编程实战源码 附有本书所有源码,maven 导入 eclipse或idea
java并发编程艺术java并发编程艺术java并发编程艺术java并发编程艺术java并发编程艺术
JAVA并发编程实践英文版很不错,运用了n多知识。 本书作者都是Java Community Process JSR 166专家组(并发工具)的主要成员,并在其他很多JCP专家组里任职。Brian Goetz有20多年的软件咨询行业经验,并著有至少75篇...
深入讲解java并发编程技术,多线程、锁以及java内存模型等
《Java并发编程的艺术》内容涵盖Java并发编程机制的底层实现原理、Java内存模型、Java并发编程基础、Java中的锁、并发容器和框架、原子类、并发工具类、线程池、Executor框架等主题,每个主题都做了深入的讲解,同时...
java并发编程内部分享PPT
这就是最正宗的《Java 并发编程实战》带目录 用福昕阅读器打开查看特别的清晰
java 并发编程的艺术pdf清晰完整版 源码
Java 并发编程实战.pdf 目录齐全
《JAVA并发编程实践》随着多核处理器的普及,使用并发成为构建高性能应用程序的关键。Java 5以及6在开发并发程序中取得了显著的进步,提高了Java虚拟机的性能以及并发类的可伸缩性,并加入了丰富的新并发构建块。在...
java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java...
Java高并发编程,构建并发编程知识体系,提升面试成功率,完整版17章视频教程下载。 本课程将结合大量图示及代码演示,带你掌握多线程并发编程(线程安全,线程调度,线程封闭,同步容器等)与高并发处理思路与手段...
java并发编程与实践是java高并发的分析文档,分析并介绍了高并发的解决方案。
java并发编程实战 pdf
62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java...
第一部分 基础知识 第2章 线程安全性 2.1 什么是线程安全性 2.2 原子性 2.2.1 竞态条件 2.2.2 示例:延迟初始化中的竞态条件 2.2.3 复合操作 2.3 加锁机制 2.3.1 内置锁 2.3.2 重入 2.4 用锁来保护状态 ...
《JAVA并发编程实践》随着多核处理器的普及,使用并发成为构建高性能应用程序的关键。Java 5以及6在开发并发程序中取得了显著的进步,提高了Java虚拟机的性能以及并发类的可伸缩性,并加入了丰富的新并发构建块。在...