class RuntimeDemo { public static void main(String[] args) throws Exception { Runtime r = Runtime.getRuntime(); Process p = r.exec(\//运行指定的程序 Thread.sleep(4000); p.destroy(); //杀掉进程 } }
--------------------------------------------------------------------------------------------------------------------
API--- java.util.Math: 用于数学运算的工具类,属性和行为都是静态的。该类是final不允许继承。
static double ceil(double a) ; //返回大于指定数值的最小整数 static double floor(double a) ; //返回小于指定数值的最大整数 static long round(double a) ; //四舍五入成整数 static double pow(double a, double b) ; //a的b次幂 static double random(); //返回0~1的伪随机数 public static void main(String[] args) { Random r = new Random(); for(int x=0; x<10; x++) { //double d = Math.floor(Math.random()*10+1); //int d = (int)(Math.random()*10+1); int d = r.nextInt(10)+1; System.out.println(d); } }
-------------------------------------------------------------------------------------------------------------------- API--- java.util.Date:日期类,月份从0-11; /* 日期对象和毫秒值之间的转换。 1,日期对象转成毫秒值。Date类中的getTime方法。 2,如何将获取到的毫秒值转成具体的日期呢? Date类中的setTime方法。也可以通过构造函数。 */ //日期对象转成毫秒值 Date d = new Date(); long time1 = d.getTime(); long time2 = System.currentTimeMillis(); / /毫秒值。 //毫秒值转成具体的日期 long time = 1322709921312l; Date d = new Date(); d.setTime(time);
/* 将日期字符串转换成日期对象:使用的就是DateFormat方法中的 Date parse(String source) ; */
46 / 67
public static void method() throws Exception { String str_time = \ DateFormat df = new SimpleDateFormat(\ //SimpleDateFormat作为可以指定用户自定义的格式来完成格式化。 Date d = df.parse(str_time); } /* 如果不需要使用特定的格式化风格,完全可以使用DateFormat类中的静态工厂方法获取具体的已经封装好风格的对象。getDateInstance();getDateTimeInstance(); */ Date d = new Date(); DateFormat df = DateFormat.getDateInstance(DateFormat.LONG); df = DateFormat.getDateTimeInstance(DateFormat.LONG,DateFormat.LONG); String str_time = df.format(d); //将日期对象转换成字符串的方式:DateFormat类中的format方法。 //创建日期格式对象。 DateFormat df = new SimpleDateFormat(); //该对象的建立内部会封装一个默认的日期格式。11-12-1 下午1:48 //如果想要自定义日期格式的话。可使用SimpleDateFormat的构造函数。将具体的格式作为参数传入到构造函数中。如何表示日期中年的部分呢?可以必须要参与格式对象文档。 df = new SimpleDateFormat(\年MM月dd日 HH:mm:ss\ //调用DateFormat中的format方法。对已有的日期对象进行格式化。 String str_time = df.format(d);
-------------------------------------------------------------------------------------------------------------------- API--- java.util. Calendar:日历类 public static void method(){ Calendar c = Calendar.getInstance(); System.out.println(c.get(Calendar.YEAR)+\年\月\ +getNum(c.get(Calendar.DAY_OF_MONTH))+\日\ +\星期\ } public static String getNum(int num){ return num>9 ? num+\ } public static String getWeek(int index){ /* 查表法:建立数据的对应关系. 最好:数据个数是确定的,而且有对应关系。如果对应关系的一方,是数字,而且可以作为角标,那么可以通过数组来作为表。 */ String[] weeks = {\日\一\二\三\四\五\六\ return weeks[index]; }
------------------------------------------------------------------------------------------------------------------------------------------------
IO流:★★★★★,用于处理设备上数据。在流中一般以字节的形式存放着数据!
47 / 67
流:可以理解数据的流动,就是一个数据流。IO流最终要以对象来体现,对象都存在IO包中。 流也进行分类:
1:输入流(读)和输出流(写)。
2:因为处理的数据不同,分为字节流和字符流。
字节流:处理字节数据的流对象。设备上的数据无论是图片或者dvd,文字,它们都以二进制存储的。二进制的最终都是以一个8位为数据单元进行体现,所以计算机中的最小数据单元就是字节。意味着,字节流可以处理设备上的所有数据,所以字节流一样可以处理字符数据。
那么为什么要有字符流呢?因为字符每个国家都不一样,所以涉及到了字符编码问题,那么GBK编码的中文用unicode编码解析是有问题的,所以需要获取中文字节数据的同时+ 指定的编码表才可以解析正确数据。为了方便于文字的解析,所以将字节流和编码表封装成对象,这个对象就是字符流。只要操作字符数据,优先考虑使用字符流体系。
注意:流的操作只有两种:读和写。
流的体系因为功能不同,但是有共性内容,不断抽取,形成继承体系。该体系一共有四个基类,而且都是抽象类。
字节流:InputStream OutputStream 字符流:Reader Writer
在这四个系统中,它们的子类,都有一个共性特点:子类名后缀都是父类名,前缀名都是这个子类的功能名称。
-------------------------------------------------------------------------------------------------------------------- public static void main(String[] args) throws IOException { //读、写都会发生IO异常 /* 1:创建一个字符输出流对象,用于操作文件。该对象一建立,就必须明确数据存储位置,是一个文件。 2:对象产生后,会在堆内存中有一个实体,同时也调用了系统底层资源,在指定的位置创建了一个存储数据的文件。 3:如果指定位置,出现了同名文件,文件会被覆盖。 */ FileWriter fw = new FileWriter(\ /* 调用Writer类中的write方法写入字符串。字符串并未直接写入到目的地中,而是写入到了流中,(其实是写入到内存缓冲区中)。怎么把数据弄到文件中? */ fw.write(\ fw.flush(); // 刷新缓冲区,将缓冲区中的数据刷到目的地文件中。 fw.close(); // 关闭流,其实关闭的就是java调用的系统底层资源。在关闭前,会先刷新该流。 }
close()和flush()的区别:
flush():将缓冲区的数据刷到目的地中后,流可以使用。
close():将缓冲区的数据刷到目的地中后,流就关闭了,该方法主要用于结束调用的底层资源。这个动作一定做。
48 / 67
-------------------------------------------------------------------------------------------------------------------- io异常的处理方式:io一定要写finally;
FileWriter写入数据的细节:
1:window中的换行符:\\r\\n两个符号组成。 linux:\\n。 2:续写数据,只要在构造函数中传入新的参数true。 3:目录分割符:window \\\\ /
public static void main(String[] args) { FileWriter fw = null; try { fw = new FileWriter(\,true); fw.write(\ } catch (IOException e ){ System.out.println(e.toString()+\ } finally{ if(fw!=null) try{ fw.close(); } catch (IOException e){ System.out.println(\ } } }
-------------------------------------------------------------------------------------------------------------------- FileReader:使用Reader体系,读取一个文本文件中的数据。返回 -1 ,标志读到结尾。 import java.io.*;
class FileReaderDemo { public static void main(String[] args) throws IOException { /* 创建可以读取文本文件的流对象,FileReader让创建好的流对象和指定的文件相关联。 */ FileReader fr = new FileReader(\ int ch = 0; while((ch = fr.read())!= -1) { //条件是没有读到结尾 System.out.println((char)ch); //调用读取流的read方法,读取一个字符。 read()方法一次读一个字节的二进制数据—是int型的! } fr.close(); } }
-------------------------------------------------------------------------------------------------------------------- 读取数据的第二种方式:第二种方式较为高效,自定义缓冲区。 import java.io.*;
49 / 67
class FileReaderDemo2 { public static void main(String[] args) throws IOException { FileReader fr = new FileReader(\//创建读取流对象和指定文件关联。 //因为要使用read(char[])方法,将读取到字符存入数组。所以要创建一个字符数组,一般数组的长度都是1024的整数倍。 char[] buf = new char[1024];//读取的字符数组长度是1024 int len = 0; while(( len=fr.read(buf)) != -1) { System.out.println(new String(buf,0,len));//将char类型的数据从0到len转换成String } fr.close(); } }
-------------------------------------------------------------------------------------------------------------------- IO中的使用到了一个设计模式:装饰设计模式。 装饰设计模式解决:对一组类进行功能的增强。 包装:写一个类(包装类)对被包装对象进行包装; * 1、包装类和被包装对象要实现同样的接口; * 2、包装类要持有一个被包装对象;
* 3、包装类在实现接口时,大部分方法是靠调用被包装对象来实现的,对于需要修改的方法我们自己实现;
-------------------------------------------------------------------------------------------------------------------- 字符流:
Reader:用于读取字符流的抽象类。子类必须实现的方法只有 read(char[], int, int) 和 close()。 |---BufferedReader:从字符输入流中读取文本,缓冲各个字符,从而实现字符、数组和行的高效读取。 可以指定缓冲区的大小,或者可使用默认的大小。大多数情况下,默认值就足够大了。 |---LineNumberReader:跟踪行号的缓冲字符输入流。此类定义了方法 setLineNumber(int) 和 getLineNumber(),它们可分别用于设置和获取当前行号。
|---InputStreamReader:是字节流通向字符流的桥梁:它使用指定的 charset 读取字节并将其解码为字符。它使用的字符集可以由名称指定或显式给定,或者可以接受平台默认的字符集。 |---FileReader:用来读取字符文件的便捷类。此类的构造方法假定默认字符编码和默认字节缓冲区大小都是适当的。要自己指定这些值,可以先在 FileInputStream 上构造一个 InputStreamReader。
|---CharArrayReader: |---StringReader:
-------------------------------------------------
Writer:写入字符流的抽象类。子类必须实现的方法仅有 write(char[], int, int)、flush() 和 close()。 |---BufferedWriter:将文本写入字符输出流,缓冲各个字符,从而提供单个字符、数组和字符串的高效写入。
|---OutputStreamWriter:是字符流通向字节流的桥梁:可使用指定的 charset 将要写入流中的字符编码成字节。它使用的字符集可以由名称指定或显式给定,否则将接受平台默认的字符集。 |---FileWriter:用来写入字符文件的便捷类。此类的构造方法假定默认字符编码和默认字节缓冲区大小都是可接受的。要自己指定这些值,可以先在 FileOutputStream 上构造一个 OutputStreamWriter。 |---PrintWriter:
|---CharArrayWriter: |---StringWriter:
50 / 67