风流不在谈锋胜,袖手无言味最长。这篇文章主要讲述Android学习笔记 JAVA基础知识回顾相关的知识,希望能为你提供帮助。
一、接口1)接口中定义的方法都是public权限,并且默认为public,而不是default。
【Android学习笔记 JAVA基础知识回顾】2)接口的实现(implements)是特殊的继承,类似于父类子类的关系,可以向上转型(非常重要)。
3)一个类可以实现多个接口;一个接口可以继承多个接口。
二、静态变量/方法1)如果某方法(或变量)声明为static,则可以直接使用“类名.方法名(或变量名)”调用。
2)静态方法只能使用静态变量。
三、静态工厂模式核心思想:把生成对象的代码(使用new来调用构造函数的方法)封装在工厂类中,降低代码重复率。
例如:HPPrinter类和CanonPrinter类继承自Printer类,两者都包含print()方法但实现方法不同。如果现在要分开实现print()方法,则要分开生成对象,然后调用该方法,并且如果新增一台其他类型的Printer的话还需要重复这一步骤。静态工厂模式就是使用一个方法(写到一个PrinterFactory类里),传入类型为Printer的参数,然后执行print()方法。利用向上转型,只要是Printer的子类都适用。
四、包在命令行环境下编译java文件,如果声明了包名(package),命令需要修改为:
javac -d . Test.java
("."是指新生成的文件夹放于当前目录,“-d”是指directory)
并且执行时需要加上包名,如
java pack.Test
五、权限public >
protected >
default >
private
1)public可以包外访问,而default只能包内访问。
2)private不能类外访问。
3)protected拥有default所拥有的权限(但不能用于修饰类),而且可以跨包继承。子类和父类不在一个包中,但是子类可以使用父类中被修饰为protected的成员变量和方法。
4)public类在一个文件中最多只能有一个,此时必须和java文件同名。没有public类则无此要求。
5)如果在权限不足的情况下继承,继承本身不会出错(编译不会报错),但是成员变量和方法不允许访问,访问时会报错。
六、异常
文章图片
1)throw:抛出异常
2)throws:声明有可能产生异常,一旦声明了就不需要在该函数内处理,而是可以在调用该函数时使用try...catch来处理。
七、内部类和匿名内部类1)设B是A的内部类,则生成B的对象前需要先生成A的对象:A.B b = new A().new B();
2)内部类可以使用外部类的成员变量,每一个内部类都有与其相对应的外部类。内部类不能使用外部方法的局部变量,除非声明为final。
3)匿名内部类:
b.fun(new A(){ public void doSomething(){ System.out.println("匿名内部类"); } //A是接口,这里直接生成一个实现了该接口的对象。 })
八、I/O
文章图片
注:输入和输出是相对程序而言的
1)字节流
FileInputStream继承自InputStream(抽象);FileOutputStream继承自OutputStream(抽象)。
InputStream: int read(byte[] b, int off, int len)
OutputStream: void write(byte[] b, int off, int len)
FileInputSream fis = null; try{ fis = new FileInputStream(""e:/src/from.txt); byte [] buffer = new byte[100]; fis.read(buffer,0,buffer.length); }
- 声明输入流引用。
- 生成代表输入流的对象。
- 生成一个字节类数组。
- 调用输入流对象的read方法,读取数据。
String s = new String(buffer); s = s.trim(); //调用String对象的trim()方法,将会去掉这个字符串的首位空格和空字符
2)大文件的读写方法
while(true){ int temp = fis.read(buffer,0,buffer.length); if( temp = -1){//返回值表示读取的数量,为-1表示读取结束; break; }//每次调用read()(或者类似的readLine())读指针都会向后移 }
注:finally里要关闭fis和fos,而且这个语句也是要被包裹在try...catch里的。
3)字符流
FileReader继承自Reader(抽象),FileWriter继承自Writer(抽象)。
区别于字节流,buffer是char类型的数组。
4)节点流和处理流
BufferedReader——字符输入处理流
BufferedReader的初始化需要以FileReader(或其他Reader)为参数,即可以在普通的节点流的基础上添加新的功能。这被称为“装饰者模式”。
九、线程 1)创建线程的方法
方法一:定义一个线程类,它继承Thread,并重写其中的run()方法,方法run()称为线程体;由于JAVA只支持单继承,用这种方法定义的类不能再继承其他类。
run()是public方法。
调用线程方法:生成线程类的对象,然后调用start()方法。
注:实际运行时存在3个(或以上)个线程:主程序线程、用户定义的线程和垃圾回收线程。主程序线程和用户定义的线程交替进行,无规律。
若调用时写的是run()而不是start(),程序会先执行完run()然后在执行其他,此时并不是多线程模型。
方法二:提供一个实现接口Runnable的类作为线程的目标对象,在初始化一个Thread类或者Thread子类的线程对象时,把目标对象传递给这个线程实例,由该目标对象提供线程体。用匿名内部类会简单很多。
-class RunnableImpl implements Runnable{run(){}}
-Runnable ri = new RunnableImpl()
-Thread t = new Thread(ri)
-t.start()
注:在实际开发中尽量少用继承,因为Java只支持单继承,故方法二更常用。
2)线程的简单控制方法
1.中断线程Thread.sleep();
Thread.yield(); //放弃CPU,然后和其他线程一起争夺CPU
//以上都是静态方法
2.设置线程的优先级getPriority();
setPriority();
//线程的优先级最大是10,最小是1,可以使用Thread所提供的静态常量来设置(max_priority,min_priority)。
3)线程的同步控制
-.每个线程都有名字,可以通过getName()和setName()操作。
-Thread Thread.currentThread用于获取当前正在执行这段代码的线程。
-为避免同步错误,引入同步代码块
synchronized(this){
//该进程获得同步锁
//执行完该代码块才允许其他线程使用CPU
}
推荐阅读
- android 上线流程
- 从Linux系统内存逐步认识Android应用内存
- AndroidLruCache压缩图片有效避免程序OOM
- Android仿QQ界面
- Android 4.4 沉浸式透明状态栏与导航栏
- 谈谈我对Android View事件分发的理解
- Android Camera详解
- Gradle with Android
- Android 如何判断指定服务是否在运行中 “Service”