码迷,mamicode.com
首页 > 其他好文 > 详细

20145301第七周学习总结

时间:2016-04-18 00:59:49      阅读:241      评论:0      收藏:0      [点我收藏+]

标签:

20145301第七周学习总结

教材学习内容总结

  • 时间的度量 格林威治时间,简称GMT时间,由观察太阳而得来;世界时,UT;国际原子时,TAI;世界协调时间,UTC;Unix时间,以1970年1月1日00:00:00为起点而经过的秒数,不考虑闰秒修正;epoch,以1970年1月1日00:00:00为起点而经过的毫秒数。

  • 年历简介 儒略历,四年一闰;格里高利历改革了儒略历;ISO 8601标准在数据定义上大部分与格里高利历相同。 认识时区 日光节约时间。

  • Date 使用Date实例的各getTime可以获得epoch毫秒数,**Data实例只用来当做时间轴上的某一瞬间;利用DataFormat可以对字符串格式进行处理,分别有GetDateInstance、GetTimeInstance、GetDateTimeInstance

  • DateFormat java.text.DateFormat复责字符串时间格式处理,DataFormat是个抽象类,其操作类为java.text.SimpleDataFormat,getDataInstance()、getTimeInstance()、getDataTimeInstance()等静态用法;可以直接构建SimpleDataFormat实例,或是使用DataFormat的;直接构建SimpleDateFormat,可以自定义字符串格式 parse方法可以将指定的字符串剖析Date实例

  • Calendar Calendar实例取得某个时间日期信息,或者对时间日期进行操作;Calendar是个抽象类,java.util.GregorianCalendar是其子类,通过Calendar的getInstance()取得的Calendar实例,默认就是取得GregorianCalendar实例;比较两个Calendar的时间日期先后,使用after()或before()方法;取得Calendar实例后,可以取得年月日信息,可以进行设定,可以进行运算来改变。

  • TimeZone TimeZone的getdefault可以取得默认时区的信息;Calender在调用getInstance()时可以指定Timezone,如果已经取得Calender实例,可以通过setTimeZone()的方法设定时区。

  • 机器时间观点的API Date实例只代表机器观点的时间信息;使用Instant的静态方法now()取得Instant实例,ofEpochMilli()可以指定Java epoch毫秒数,ofEpochSecod()指定秒数;取得Instant实例后,可以使用plusSecond()、plusMillis()、plusNanos()、minusSeconds()、minusMillis()、 MinusNanos()做时间轴上的运算,返回新的Instant实例,代表运算后的时间。

  • 人类时间观点的API Date实例只代表机器观点的时间信息;在上面那些类的基础上可以使用ZonedDateTime等来进行补充;Month是enum类型,取得代表月份的数字,取得月份要通过getValue()方法,而不是使用oridinal()方法。

  • TemporalAmount 时间计量,新时间和日期用API用类Duration来定义,对于年、月、日、星期的日期差,可使用Period类定义,静态方法ofDays()、ofMonths()、ofWeeks(),返回Period实例。

  • TemporalUnit plus()方法的另一重载版本,接受java.time.temporal.TemporalUnit实例,java.time.temporal.ChronoUnit是其实做类,使用enum实做。 Temporal plus()定义在Temporal接口上;Instant、LocalDate、LocalDateTime、LocatTime、OffsetTime、ZonedDateTime等类,都操作了 Temporal 接口。

  • TemporalAccessor Temporal是 TemporalAccessor的子接口。 年历系统设计 DK8采用一年历系统设计,也就是说,java.time套件中的类在需要实行年历系统时都是采用单一的ISO8601年历系统。需要明确实行java.time.chrono.Chronology接口的类。

教材学习中的问题和解决过程 这章教材内容基本都能够理解 代码调试中的问题和解决过程 问题 P441 TemporalAmout 下方的代码

解决过程 按要求输入代码,并且表明了 ofPattern 的类名

结果显示有错误,但并不理解错误原因是什么

注释掉 ofPattern 那一句试试

可以成功通过,那假如用 SimpleDateFormat 的方法来代替代码中的 ofPattern

不可以的,结果显示不能将 Object 转成 Date

那就试试用 Calendar 来重新表达

终于是有可以成功的了。

10.2 字符处理类

  • 包java.io中的两个类Reader和Writer,他们是能将字节流以字符流方式进行读写的对象,因此字符流在本质上是以Reader和Writer封装的字节流。Reader和Writer都是抽象类,这两个类都实现了声明close()方法的AutoCloseable接口。

  • Reader和Writer类以及他们的子类本身都不是流,但是他们提供了一些方法,可用于将底层的流作为字符流读写。因此,通常使用底层的InputStream和OutputStream对象来创建Reader和Writer对象。   

    第十一章部分 - 线程与并行API

    11.1 线程

  • 线程 可以拥有多个流程,也就是多线程程序如果想在main()以外独立建立流程,可以撰写类操作java.lang.Runnable接口,流程的进入点是操作在run()方法中;从main()开始的流程会由主线程执行,创建Thread实例来执行runnable实例定义的run()方法;要启动线程执行指定流程,必须要调用Thread实例的start()。 Thread与Runnable 将流程定义在 Runnable 的 run()方法中;继承 Thread 类,重新定义 run()方法。
  • 线程生命周期 一个 Thread被标示为 Daemon线程,在所有非Daemon线程都结束时,JVM自动终止;使用 setDaemon()方法来设定一个线程是否为 Deamon线程,使用 isDaemon()方法判断线程是否为 Deamon线程默认所有从 Deamon线程产生的线程也是 Deamon线程;
  • 使用 Thread的 setpriority()方法设定优先权,1-10,默认值是5让线程进入 Blocked状态,调用 Thread.sleep()等方法,等待输入/输出线程因输入/输出进入 Blocked状态,在完成输入/输出后,会回到 runnable状态;join()将线程加入另一线程的流程中;线程完成run()方法后,会进入Dead,进入Dead的线程不可以再次调用start()方法。
  • ThreadGroup 线程一旦归入某个群组,就无法更换;java.lang.ThreadGroup可以管理群组中的线程; interrupt()方法可以中断群组中的所有线程;
  • setMaxpriority()方法可以设定群组中所有线程最大优先权; enumerate()方法可以一次取得群组中所有线程; activeCount()方法取得群组的线程数量; uncaughtException()方法处理某个线程未被捕捉的异常。 synchronized与volatile 被标示为 synchronized的区块将会被监控,任何线程要执行该区块必须先取得指定的对象锁定;线程尝试执行synchronized区块而进入 Blocked,在取得锁定之后,会先回到Runnable状态,等待排入 Runnning状态; synchronized要求达到的所标示区块的互斥性,与可见性;在变量上声明 volatile,表示变量是不稳定、易变的,可能在多线程下存取,保证变量的可见性。
  • 在java中,如果想在main()以外独立设计流程,可以撰写类操作java.lang.Runnable接口,流程的进入点是操作在run()方法中。如果想要为JVM加装CPU,就是创建Thread实例,要启动额外CPU就是调用Thread实例的start()方法,额外CPU执行流程的进入点,可以定义在Runnale接口的run()方法中。
  • 操作Runnable接口的好处就是较有弹性,你的类还有机会继承其他类。若继承了Thread,那该类就是一种Thread,通常是为了直接利用Thread中定义的一些方法,才会继承Thread来操作。

    11.2 并行API

  • Lock:相对与Thread模型的隐式的锁对象,Lock提供了显式的锁操作从而简化应用程序。Executors:提供了一组HighLevelAPI用来执行和管理并行任务。  
  • ConcurrentCollections:包含了一组支持并行处理的数据结构,大大简化了并行编程难度。AtomicVariables:减少了同步操作并且避免数据不一致。Fork/Join框架:提供了进程操作的支持。
  • ReadWriteLock接口定义了读取锁定与写入锁定行为,可以使用readLock()、writeLock()方法返回Lock操作对象。ReentrantReadWriteLock是ReadWriteLock接口的主要操作类,readLock()方法会返回ReentrantReadWriteLock.ReadLock实例,writeLock()犯法会返回ReentrantReadWriteLock.WriteLock实例。
  • Condition接口用来搭配Lock,最基本用法就是达到Object的wait()、notify()、notifyAll()方法的作用。Condition的await()、signal()、signalAll()方法,可视为Object的wait()、notify()、notifyAll()方法的对应。

其他

利用扩展Thread类创建的多个线程,虽然执行的是相同的代码,但彼此相互独立,且各自拥有自己的资源,互不干扰。

心得体会

这两章的学习感觉比较难以理解,需要更多外延学习和自己实践来去深入理解,单纯看书是远远不够的。

学习进度条

目标 代码行数 博客量学习时间重要成长
目标 4000行 30篇 400小时 ----
第一周  100/4000  2/30 15/400 hello java
第二周 350/4000 3/30 40/400 流程控制
第三周 500/4000 4/30 50/400 类与对象、封装
第四周 700/4000 5/30 70/400 继承、接口
第五周 950/4000 6/30 90/400 异常与资源管理
第六周 1200/4000 8/30 120/400 输入输出

参考资料

  • 《Java学习笔记》
  • 《Java学习笔记》学习指导
  • 毕向东java教学

20145301第七周学习总结

标签:

原文地址:http://www.cnblogs.com/5301z/p/5402849.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!