zoukankan      html  css  js  c++  java
  • Java基础之Calendar类、JNDI之XML

     一、Calendar类

    从JDK1.1版本开始,在处理日期和时间时,系统推荐使用Calendar类进行实现。在设计上,Calendar类的功能要比Date类强大很多,而且在实现方式上也比Date类要复杂一些,下面就介绍一下Calendar类的使用。

    Calendar类是一个抽象类,在实际使用时实现特定的子类的对象,创建对象的过程对程序员来说是透明的,只需要使用getInstance方法创建即可。

    1、使用Calendar类代表当前时间

                       Calendar c = Calendar.getInstance();

    由于Calendar类是抽象类,且Calendar类的构造方法是protected的,所以无法使用Calendar类的构造方法来创建对象,API中提供了getInstance方法用来创建对象。

    使用该方法获得的Calendar对象就代表当前的系统时间,由于Calendar类toString实现的没有Date类那么直观,所以直接输出Calendar类的对象意义不大。

    2、使用Calendar类代表指定的时间

                       Calendar c1 = Calendar.getInstance();

                       c1.set(2009, 3 - 1, 9);

    使用Calendar类代表特定的时间,需要首先创建一个Calendar的对象,然后再设定该对象中的年月日参数来完成。

    set方法的声明为:

             public final void set(int year,int month,int date)

    以上示例代码设置的时间为2009年3月9日,其参数的结构和Date类不一样。Calendar类中年份的数值直接书写,月份的值为实际的月份值减1,日期的值就是实际的日期值。

    如果只设定某个字段,例如日期的值,则可以使用如下set方法:

             public void set(int field,int value)

    在该方法中,参数field代表要设置的字段的类型,常见类型如下:

             Calendar.YEAR——年份

             Calendar.MONTH——月份

             Calendar.DATE——日期

             Calendar.DAY_OF_MONTH——日期,和上面的字段完全相同

             Calendar.HOUR——12小时制的小时数

             Calendar.HOUR_OF_DAY——24小时制的小时数

             Calendar.MINUTE——分钟

             Calendar.SECOND——秒

             Calendar.DAY_OF_WEEK——星期几

    后续的参数value代表,设置成的值。例如:

             c1.set(Calendar.DATE,10);

    该代码的作用是将c1对象代表的时间中日期设置为10号,其它所有的数值会被重新计算,例如星期几以及对应的相对时间数值等。

    3、获得Calendar类中的信息

                       Calendar c2 = Calendar.getInstance();

                       //年份

                       int year = c2.get(Calendar.YEAR);

                       //月份

                       int month = c2.get(Calendar.MONTH) + 1;

                       //日期

                       int date = c2.get(Calendar.DATE);

                       //小时

                       int hour = c2.get(Calendar.HOUR_OF_DAY);

                       //分钟

                       int minute = c2.get(Calendar.MINUTE);

                       //秒

                       int second = c2.get(Calendar.SECOND);

                       //星期几

                       int day = c2.get(Calendar.DAY_OF_WEEK);

                       System.out.println("年份:" + year);

                       System.out.println("月份:" + month);

                       System.out.println("日期:" + date);

                       System.out.println("小时:" + hour);

                       System.out.println("分钟:" + minute);

                       System.out.println("秒:" + second);

                       System.out.println("星期:" + day);

    使用Calendar类中的get方法可以获得Calendar对象中对应的信息,get方法的声明如下:

             public int get(int field)

    其中参数field代表需要获得的字段的值,字段说明和上面的set方法保持一致。需要说明的是,获得的月份为实际的月份值减1,获得的星期的值和Date类不一样。在Calendar类中,周日是1,周一是2,周二是3,依次类推。

    4、其它方法说明

    其实Calendar类中还提供了很多其它有用的方法,下面简单的介绍几个常见方法的使用。

    a、add方法

                       public abstract void add(int field,int amount)

    该方法的作用是在Calendar对象中的某个字段上增加或减少一定的数值,增加是amount的值为正,减少时amount的值为负。

             例如在计算一下当前时间100天以后的日期,代码如下:

                       Calendar c3 = Calendar.getInstance();

                       c3.add(Calendar.DATE, 100);

                       int year1 = c3.get(Calendar.YEAR);

                       //月份

                       int month1 = c3.get(Calendar.MONTH) + 1;

                       //日期

                       int date1 = c3.get(Calendar.DATE);

                       System.out.println(year1 + "年" + month1 + "月" + date1 + "日");

    这里add方法是指在c3对象的Calendar.DATE,也就是日期字段上增加100,类内部会重新计算该日期对象中其它各字段的值,从而获得100天以后的日期,例如程序的输出结果可能为:

                       2009年6月17日

    b、after方法

                       public boolean after(Object when)

    该方法的作用是判断当前日期对象是否在when对象的后面,如果在when对象的后面则返回true,否则返回false。例如:

                       Calendar c4 = Calendar.getInstance();

                       c4.set(2009, 10 - 1, 10);

                       Calendar c5 = Calendar.getInstance();

                       c5.set(2010, 10 - 1, 10);

                       boolean b = c5.after(c4);

                       System.out.println(b);

    在该示例代码中对象c4代表的时间是2009年10月10号,对象c5代表的时间是2010年10月10号,则对象c5代表的日期在c4代表的日期之后,所以after方法的返回值是true。

    另外一个类似的方法是before,该方法是判断当前日期对象是否位于另外一个日期对象之前。

                       c、getTime方法

                                         public final Date getTime()

    该方法的作用是将Calendar类型的对象转换为对应的Date类对象,两者代表相同的时间点。

    类似的方法是setTime,该方法的作用是将Date对象转换为对应的Calendar对象,该方法的声明如下:

             public final void setTime(Date date)

    转换的示例代码如下:

                      Date d = new Date();

                       Calendar c6 = Calendar.getInstance();

                       //Calendar类型的对象转换为Date对象

                       Date d1 = c6.getTime();

                       //Date类型的对象转换为Calendar对象

                       Calendar c7 = Calendar.getInstance();

                       c7.setTime(d);

             5、Calendar对象和相对时间之间的互转

                                Calendar c8 = Calendar.getInstance();

                                long t = 1252785271098L;

                                //将Calendar对象转换为相对时间

                                long t1 = c8.getTimeInMillis();

                                //将相对时间转换为Calendar对象

                                Calendar c9 = Calendar.getInstance();

                                c9.setTimeInMillis(t1);

    在转换时,使用Calendar类中的getTimeInMillis方法可以将Calendar对象转换为相对时间。在将相对时间转换为Calendar对象时,首先创建一个Calendar对象,然后再使用Calendar类的setTimeInMillis方法设置时间即可。

     

    二、项目笔记

     

    一、项目团队构成

    1.前端开发工程师

    1)把设计(效果)图切(图)HTML+CSS+image+js+.......

    2)使用前端框架(Vue.jsAngularReact)开发前端应用(手机、桌面),需要服务端提供接口

       

       2.美术设计师(美工)

         1)把产品经理/项目经理设计的原型转变成效果图(App、桌面网站、系统)

         2)设计宣传资料(产品、公司、项目)

         3)杂事(名片、PPT....

     

       3.项目经理

         1)管理项目需求、与客户及项目团队沟通、指定项目计划、监管项目进度

         2)一个项目经理可能同时管理多个项目

     

       4.产品经理

         1)自己研发产品的公司通常有产品经理,规划、设计产品(面向什么用户、满足什么需要、如何在竞争中胜出、如何盈利)

         2)互联网公司一般都有产品经理

     

       5.部门经理

         1)团队的组建(面试、招聘、优化)、培训、日常行政事务(请假审批、绩效考核等)

     

      6.测试工程师

         1)找BUG、管理BUG   

         2)写文档(测试文档、产品说明书《使用手册、帮助文档》)

     

     

    三、绝对路径和相对路径

    绝对路径是以/开头,或者以协议开头

        绝对路径是以主机根目录为固定参照点

    /api/user/login

    http://www.baidu.com/abc

     

    相对路径是以字母 数字等非/开头,或者以.  ..开头

    相对路径以当前目录为参照点

    user/login

    ../login

     

    使用绝对路径的代码可以在项目中随意移动而不用修改地址

    使用相对路径的代码随位置时需要检查地址是否正确

     

    四、在JSP中使用绝对路径首先要解决应用路径(Content root)的问题

    1.获取应用路径可以使用代码块定义一个变量

     

       

     

    2.使用JSTL

    <link ..... href=”<c:url value=”/css/index.css>”>

    c:url是一个特殊标签 ,它可以将valueurl变成包含应用路径的绝对地址

     

    3.步骤

         1)导入jar

         2)把标签库tld文件都导入项目中(WEB-INF

         3)在web.xml中配置JSTL

         4)在JSP页面上添加taglib指令

               taglib指令实际上命名空间的声明

     

       4.格式

    prefix=c” :命名空间的前缀,前缀名称可以随意写,越短越好

               uri=uriuri不是一个真实网址,只是一个以网址形式存在的唯一名称

               

               当页面上写下面的标签时,需要找到url标签的解释者

           <c:url value=””>

           url标签由谁负责处理呢?就需找url标签的命名空间c,而c在 页面开头

    taglib指令声明,而且它与后面uri关联起来,urijar包中由相应声明

          urijar包中有对应声明(tld中声明相关的标签名、以及对应的类)找到类

        之后,会调用类中渲染方法生成HTML

     

     

    5.JSTL使用的是严格XML语法,标签需要闭合!

      1<c:url ...../>        

    2、<c:when .....>

              ........

             </c:when ....>

          

     

       6.JSTL常用的标签大类是

           核心标签:用来控制HTML的生成,提供了分支判断、循环生成复杂HTML的功能(根据数据生成)、还包括生成URL及跳转

           格式化标签:用来格式化数据

           函数:用来截取字符串等

     

     

    返回的是表单里的key

     

     

     五、JNDI

     

    Java Naming and DirectoryInterface Java命名和目录接口

         

    JDK只定义规范,而没有给出具体的实现

    具体的实现由Tomcat等应用容器实现

     

    名字和目录服务的目标是:

    通过提供字符串形式的名字即可获得想要对象,对象已经被初始化好

       初始化时通过配置文件中提供配置信息实现的

    不需要程序员自己new一个对象,也不需要程序员自己给构造方法传参,也不需要调用setter给属性赋值

     

    它带来的好处是:

       将对象创建需要的信息转移到配置文件中,从java代码中脱离出来

       方便之后的修改(不需要修改和编译代码)

     

    JNDI底层有很多提供程序,可以支持创建多种类型的对象,提供程序是可以扩展的

     

     

     

    六、XML   

    1. 可扩展标记语言  Extensible Markup Language

    2. 标签名可以自定义的标记语言

    3. 标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等。

    4. XML语法严格,如果语法不正确,就无法通过验证器验证

    5. 使用XML解析器解析数据时也会出错

    6. 因为XML的标签时可扩展的,所有XML有文档类型定义(DTD)语言和Schema语言类2种,帮助程序员定义新标签

     

    问:既然XML可以自定义标签,那么如果出现A程序员定义标签和B程序员定义的标签同名,怎么解决?

     

    解决方法:标签都定义在命名空间中,命名空间相当于java中的包。

    每个XML文档都有一个默认命名空间,默认命名空间中的标签不用加前缀,当引入其他命名空间的标签时,必须加前缀

      

    扩展:

    1.关于DTD

    DTD(英文Document Type Definition,中文:文档类型定义)是一套关于标记符的语法规则,是标准通用标记语言和扩展标记语言1.0版规格的一部分,是文档的验证机制,也是一个美国信息交换标准代码文本文件。它是一种保证标准通用标记语言、可扩展标记语言文档格式正确的有效方法,可通过比较文档和文档类型定义文件来看文档是否符合规范,元素和标签使用是否正确。文件实例提供应用程序一个数据交换的格式。因为文档类型定义正是让标准通用标记语言、可扩展标记语言文件能够成为数据交换标准,所以不同的公司只需定义好标准文档类型定义即可,各公司都能依文档类型定义建立文档实例,并进行验证,如此就可以轻易的建立标准和交换数据,这样满足了网络共享数据交互。

     2.关于Schema

    Schema是用于描述和规范XML文档的逻辑结构的一种语言,它最大的作用就是验证XML文件逻辑结构的正确性。

    用于描述和规范XML文档的逻辑结构的一种语言,它最大的作用就是验证XML文件逻辑结构的正确性。可以理解成与DTD(文档类型定义)功能差不多,但是Schema在当前的WEB开发环境下优越很多。

      因为它本身就是一个有效的XML文档,因而可以更直观地了解XML的结构。除此之外,Schema支持命名空间,内置多种简单和复杂的数据类型,并支持自定义数据类型。由于存在这么多的优点,所以Schema渐渐成为XML应用的统一规范。


     

    XML实体符号

      XML Entities(Entity)

      因为XML使用了< > &

      当节点内部(标签内容区域)需要表示< > 这种语法符号时,需要实体代码,而不能直接写语法符号

        

    错误示例:<expr>a<b</expr>

    正确示例:<expr>a&It;b</expr>

     

    实体符号以&开头

    & ---->  &

     

     

    ServletJSPServlet传数据

    使用转发跳转时,可以将数据放在request对象中

    request.setAttribute(“key”,value);    value可以是对象!

    使用重定向时,需要将数据放在URL

     response.sendRedirect(“..../index.jsp?errorMessage=XXXXX”);

    这种方式只能传字符串,而且不能太长

     

     

    try  with  resources

       Java 7 支持新语法

       可以自动帮助我们调用close()方法,close()方法在AutoCloseable这个接口中定义的

     

      try(资源1;资源2;资源3){

         //资源3关闭

         //资源2关闭

        //资源1关闭

    }

    catch(){

    }

     

     

     

    WEB-INFMETA-INF中的资源不能通过浏览器直接访问!!!

  • 相关阅读:
    快速获取JOB运行结果
    快速获取DB服务器当前 MEM CPU的资源消耗
    Mongodb Sharding+Replica Set
    MongoDB replSet
    Journal工作原理
    Oracle索引梳理系列(八)- 索引扫描类型及分析(高效索引必备知识)
    Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系
    Oracle索引梳理系列(六)- Oracle索引种类之函数索引
    Oracle索引梳理系列(五)- Oracle索引种类之表簇索引(cluster index)
    Oracle索引梳理系列(四)- Oracle索引种类之位图索引
  • 原文地址:https://www.cnblogs.com/yangxiansen/p/7860046.html
Copyright © 2011-2022 走看看