20155229 2016-2017-2 《Java程序设计》第六周学习总结
教材学习内容总结
第十章
- Java中,输入串流代表对象为java.io.InputStream,输出串流代表对象为java.io.OutputStream
- InputStream的read()方法每次尝试读入byte数组长度的数据,并返回实际读入的字节;OutputStream的write()方法,指定要写出的byte数组、初索引与数据长度。
- System的setIn()方法指定InputStream,重新制定标准输入来源;setOut()方法指定PrintStream,将结果输出至制定的目的地。
- InputStream、OutStream提供串流基本操作,如果想要为输入/输出的数据做加工处理,则可以使用打包器类。常用的打包器具备缓冲区作用的BufferedOutputStream、BufferedInputStream,具备数据转换处理的DataInputStream、DataOutputStream,具备对象串行化能力的ObjectInputStream、ObjectOutputStream等
第十一章
- 在java中,如果想在main()以外独立设计流程,可以撰写类操作java.lang.Runnable接口,流程的进入点是操作在run()方法中。
- 在java中,从main()开始的流程会由主线程执行,可以创建Thread实例来执行Runnable实例定义的run()方法。
- 使用Lock
lock接口主要操作类之一为ReentrantLock,可以达到synchronized的作用。
为了避免调用Lock()后,在后续执行流程中抛出异常而无法解除锁定,一定要在finally中调用Lock对象的unlock()方法。
Lock接口还定义了tryLock()方法,如果线程调用tryLock()可以取得锁定会返回true,若无法取得锁定并不会发生阻断,而是返回false。
- 使用ReadWriteLock
ReadWriteLock接口定义了读取锁定与写入锁定行为,可以使用readLock()、writeLock()方法返回Lock操作对象。ReentrantReadWriteLock是ReadWriteLock接口的主要操作类,readLock()方法会返回ReentrantReadWriteLock.ReadLock实例,writeLock()犯法会返回ReentrantReadWriteLock.WriteLock实例。
-
BlockedQueue是Queue的子接口,新定义了put()、take()方法。
-
ConcurrentMap是Map的子接口,其定义了putIfAbsent()、remove()、replace()等方法。这些方法都是原子操作。
-
ConcurrentHashMap是ConcurrentMap的操作类,ConcurrentNavigableMap是ConcurrentMap的子接口,其操作类为ConcurrentSkipListMap,可视为支持并行操作的TreeMap版本。
教材学习中的问题和解决过程
-
问题一:
“线程池”是什么?
-
解决:
-
线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。如果某个线程在托管代码中空闲(如正在等待某个事件),则线程池将插入另一个辅助线程来使所有处理器保持繁忙。如果所有线程池线程都始终保持繁忙,但队列中包含挂起的工作,则线程池将在一段时间后创建另一个辅助线程但线程的数目永远不会超过最大值。超过最大值的线程可以排队,但他们要等到其他线程完成后才启动。
java中有四种线程池:
代码调试中的问题和解决过程
- 问题一:在编译p355的代码时,出现以下错误
错误说的是try不带有catch和finally,我检查了代码,try和finally都在,最后我发现在(res)后面少了个‘{’,导致
调整过后,代码无误。
- 问题二:在编译p377的ProducerConsumerDemo3代码时,出现以下错误
找不到Producer3,我搜查Producer3的代码,发现代码无误,并且能够通过编译,所以不应该会出现以上情况,等在此编译这个代码时,发现无误,所以综上,我当时没有编译Producer3的代码,所以编译新代码时,找不到Producer3关键字。