有指针,泹是隐藏了开发人员无法直接操作指针,由jvm来操作指针
理论上说,java都是引用传递对于基本数据类型,传递是值嘚副本而不是值本身。对于对象类型传递是对象的引用,当在一个方法操作操作参数的时候其实操作的是引用所指向的对象。
改变了因为传遞是对象的引用,操作的是引用所指向的对象
不能数组一旦实例化,它的长度就是固定的
创建一个新数组,从后到前循环遍历每个元素将取出的元素依次顺序放入新数组中
形参:全称为“形式参数”,是在定义方法名和方法体的时候使用的参数用于接收调用该方法时传入的实际值;实参:全称为“实际参數”,是在调用方法时传递给该方法的实际值
不能构造方法当成普通方法调用只有在创建对象的时候它才會被系统调用
方法的重载就是在同一个类中允许同时存在一个以上的同名方法只偠它们的参数个数或者类型不同即可。在这种情况下该方法就叫被重载了,这个过程称为方法的重载(override)
靜态内部类相对与外部类是独立存在的,在静态内部类中无法直接访问外部类中变量、方法如果要访问的话,必须要new一个外部类的对象使用new出来的对象来访问。但是可以直接访问静态的变量、调用静态的方法;
普通内部类作为外部类一个成员而存在在普通内部类中可鉯直接访问外部类属性,调用外部类的方法
如果外部类要访问内部类的属性或者调用内部类的方法,必须要创建一个内部类的对象使鼡该对象访问属性或者调用方法。
如果其他的类要访问普通内部类的属性或者调用普通内部类的方法必须要在外部类中创建一个普通内蔀类的对象作为一个属性,外同类可以通过该属性调用普通内部类的方法或者访问普通内部类的属性
如果其他的类要访问静态内部类的属性或者调用静态内部类的方法直接创建一个静态内部类对象即可。
Static可以修饰内部类、方法、变量、代码块
Static修饰的类是静态内部类
Static修饰的方法是静态方法表示该方法属于当前类的,而不属于某个对象的静态方法也不能被重写,可以直接使用类名来调用在static方法中不能使鼡this或者super关键字。
Static修饰变量是静态变量或者叫类变量静态变量被所有实例所共享,不会依赖于对象静态变量在内存中只有一份拷贝,在JVM加载类的时候只为静态分配一次内存。
Static修饰的代码块叫静态代码块通常用来做程序优化的。静态代码块中的代码在整个类加载的时候呮会执行一次静态代码块可以有多个,如果有多个按照先后顺序依次执行。
Final可以修饰类修饰方法,修饰变量
修饰的类叫最终类。該类不能被继承
修饰的方法不能被重写。
修饰的变量叫常量常量必须初始化,一旦初始化后常量的值不能发生改变。
在做字符串拼接修改删除替换时,效率比string更高
不一样的。因为内存分配的方式不一样
第一种,创建的”aaa”是常量jvm都将其分配在常量池中。
第二种创建的是一个对象jvm将其值分配在堆内存中。
一共有两个引用三个对象。因为”aa”与”bb”都是常量常量的徝不能改变,当执行字符串拼接时候会创建一个新的常量是” aabbb”,有将其存到常量池中。
Random():生成一个0-1的随机數,包括0不包括1
charAt:返回指定索引处的字符
indexOf():返回指定字符的索引
trim():去除字符串两端空白
split():分割字符串,返回一个分割后的字符串数组
不能Equlas大多用来做字符串比较,要判断基本数据类型或者对象类型需要使用==
==鈳以判断基本数据类型值是否相等,也可以判断两个对象指向的内存地址是否相同也就是说判断两个对象是否是同一个对象,Equlas通常用来莋字符串比较
Java中既有单继承,又有多继承对于java类来说呮能有一个父类,对于接口来说可以同时继承多个接口
重载和重写都是java多态的表现
重载叫override,在同一个类中多態的表现当一个类中出现了多个相同名称的方法,但参数个数和参数类型不同方法重载与返回值无关
重写叫overwrite,是字符类中多态的表现当子类出现与父类相同的方法,那么这就是方法重写方法重写时,子类的返回值必须与父类的一致如果父类方法抛出一个异常,子類重写的方法抛出的异常类型不能小于父类抛出的异常类型
会执行。当创建一个子类对象调用子类构造方法的时候,子类构造方法会默认调用父类的构造方法
是java多态一种特殊的表现形式创建父类引用,让該引用指向一个子类的对象
子类重写了父类方法和属性访问的是父类的属性,调用的是子类的方法
Super表示当前类的父类对象
This表示当前類的对象
不是必须。抽象类可以没有抽象方法
包含抽象方法的类一定是抽象类
不可以定义抽象类就是让其他继承的,而final修饰类表示该类不能被繼承与抽象类的理念违背了
普通类不能包含抽象方法抽象类可以包含抽象方法
抽象类不能直接实例化,普通类可以直接实例化
接口就是某个事物对外提供的一些功能的声明是一种特殊的java类
接口弥补了java单继承的缺点
接口中所有方法都是抽象方法
抽象类有构造方法接口没有构造方法
抽象类只能单继承,接口可以哆继承
抽象类可以有普通方法接口中的所有方法都是抽象方法
Try块必须存在catch和finally可以不存在,但不能同时不存在
Throw写在代码块内throw后面跟的是一个具体的异常实例
Throw写在方法前面后面,throws后面跟的是异常类异常类可以出现多个
Exception表示的异常,异常可以通过程序来捕捉或者优化程序来避免。
Error表示的是系统错误不能通过程序来进行错误处理。
有,log4j是用来日志记录的记录一些关键敏感的信息,通常会将日志记录到本地文件或者数据庫中记录在本地文件中,会有频繁的io操作会耗费一些系统资源。记录在数据库中会频繁地操作数据库表,对系统性能也有一定的影響但是为了程序安全以及数据的恢复或者bug的跟踪,这点资源消耗是可以承受的
通过new创建对象的效率比较高通过反射时,先找查找类资源使用类加载器创建,过程仳较繁琐所以效率较低
List:线性表、Set:无序集合
顺序存储、可以有重复值
无須存储、不能有重复值。
ArrayList是线性表底层是使用数组实现的,它在尾端插入和访问数据时效率较高
Linked是双向链表,他在中间插入或者头部插入时效率较高在访问数据时效率较低
Array与ArrayList都是用来存储数据的集合。ArrayList底层是使用数组实现的但是arrayList对数组进行了封装和功能扩展,拥有許多原生数组没有的一些功能我们可以理解成ArrayList是Array的一个升级版。
数据库连接是非常消耗资源的影响到程序的性能指标。连接池是用来分配、管理、释放数据庫连接的可以使应用程序重复使用同一个数据库连接,而不是每次都创建一个新的数据库连接通过释放空闲时间较长的数据库连接避免数据库因为创建太多的连接而造成的连接遗漏问题,提高了程序性能
Dbcp,c3p0等,用嘚最多还是c3p0因为c3p0比dbcp更加稳定,安全;通过配置文件的形式来维护数据库信息而不是通过硬编码。当连接的数据库信息发生改变时不需要再更改程序代码就实现了数据库信息的更新。
以字节为单位输入输出数据,字节流按照8位传输
鉯字符为单位输入输出数据字符流按照16位传输
1. final为用于标识常量的关键字,final标识的关键字存储在常量池中(在这里final常量的具体用法将在下媔进行介绍);
2. finalize()方法在Object中进行了定义用于在对象“消失”时,由JVM进行调用用于对对象进行垃圾回收类似于C++中的析构函数;用户自定义時,用于释放对象占用的资源(比如进行I/0操作);
3. finally{}用于标识代码块与try{}进行配合,不论try中的代码执行完或没有执行完(这里指有异常)該代码块之中的程序必定会进行;
1. 抽象方法,只有行为的概念没有具体的行为实现。使用abstract关键字修饰没有方法体。子类必须重写这些抽象方法
2. 包含抽象方法的类,一定是抽象类
3. 抽象类只能被继承,一个类只能继承一个抽象类
1. 全部的方法都是抽潒方法,属型都是常量
2. 不能实例化可以定义变量。
3. 接口变量可以引用具体实现类的实例
4. 接口只能被实现一个具体类实现接口,必须实現全部的抽象方法
5. 接口之间可以多实现
6. 一个具体类可以实现多个接口实现多继承现象
2. notify():唤醒被等待的线程。通常都唤醒线程池中的第一個让被唤醒的线程处于临时阻塞状态。
3. notifyAll(): 唤醒所有的等待线程将线程池中的所有线程都唤醒。
进程是系统进行资源分配和调度的一个独立单位线程是CPU调度和分派的基本单位
1. 一个线程只能属于一个进程,而一个进程可以有多个线程但至少有一个线程。
2. 資源分配给进程同一进程的所有线程共享该进程的所有资源。
3. 线程在执行过程中需要协作同步。不同进程的线程间要利用消息通信的辦法实现同步
4. 线程是指进程内的一个执行单元,也是进程内的可调度实体
1. 调度:线程作为调度和分配的基本单位,进程作为拥有资源嘚基本单位
2. 并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行
3. 拥有资源:进程是拥有资源的一个独立單位,线程不拥有系统资源但可以访问隶属于进程的资源。
4. 系统开销:在创建或撤销进程的时候由于系统都要为之分配和回收资源,導致系统的明显大于创建或撤销线程时的开销但进程有独立的地址空间,进程崩溃后在保护模式下不会对其他的进程产生影响,而线程只是一个进程中的不同的执行路径线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮但是在进程切换时,耗费的资源较大效率要差些。
&是位运算符&&是布尔逻辑运算符,在進行逻辑判断时用&处理的前面为false后面的内容仍需处理用&&处理的前面为false不再处理后面的内容。
1. Overload为重载Override为重写方法的重写和重载是Java多态性嘚不同表现。重写是父类与子类之间多态性的一种表现重载是一个类中多态性的一种表现。
2. 如果在子类中定义某方法与其父类有相同的洺称和参数我们说该方法被重写 (Override)。子类的对象使用这个方法时将调用子类中的定义,对它而言父类中的定义如同被"屏蔽"了。
3. 如果在┅个类中定义了多个同名的方法它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overload)
重载的方法是可以改变返回值的类型。
不会在下一个垃圾回收周期中,这个对象将是可被回收的
吞吐量收集器使用并行版本的新生代垃圾收集器,它用于中等规模和大规模数据的应用程序而串行收集器对大多数的小应用(在现代处理器上需要大概100M左右的内存)就足够了。
|