1.IDE简介设置快捷键 :windows -> preference -> General -> Keys
自动提示快捷键需要设置 Content Assist
好用的快捷键 :
ctrl + 1 : 鼠标定位出错地方附近使用,提示各种解决方法
alt + 上下 : 换行
ctrl + alt + 上下 : 拷贝当前行
shift + 回车 : 在当前行的下面新增一行空白,光标定位到新行
shift + ctrl + 回车 : 光标所在行新增一行空白行,原有内容下移一行,光标定位到新行
全局字体样式设置 :windows -> preference -> General -> Appearance -> Basic -> Text Font
2.Junit的简单使用
import org.junit.*;
public class Demo {
//所有测试的方法都是public方法
@BeforeClass//只执行一次,标记的方法中最先执行,且为静态
public static void powerOn () {
System.out.println("@BeforeClass");
}
@Before//在每个标志了@Test的方法之前执行
public void openDir() {
System.out.println("@Before");
}
@Test//需要测试的方法
public void openFile () {
System.out.println("打开文件");
}
//普通方法,无影响
public void readFile () {
System.out.println("读取文件");
}
@Test
public void closeFile () {
System.out.println("关闭文件");
}
@After//在每个标志了@Test的方法之后执行
public void closeDir() {
System.out.println("@After");
}
@AfterClass////只执行一次,标记的方法中最后执行,且为静态
public static void powerOff () {
System.out.println("@AfterClass");
}
}
3.静态导入
实际上使用的并不多
//静态导入属性、方法、对象,直接使用,无需前缀包名
import static java.lang.Math.PI;
import static java.lang.Math.abs;
import static java.lang.System.out;
public class Demo {
public static void main(String[] args) {
int r = abs(-10);
double pi = PI;
//Math.pow没有静态导入,所以不能直接使用pow
double area = pi * Math.pow(r, 2);
out.println(r + " " + pi + " " + area);
}
}
4.自动拆箱装箱
//八种基本类型可以赋值给对应的包装类变量或者Objec变量
//同样,八种包装类对象实例也可以赋值给对应的基本类型变量
public class Demo {
public static void main(String[] args) {
Integer objI = 1;
int i = objI;
Object obj = 1;
}
}
5.增强for循环
//方便地便利数组或者实现了Iterator接口的集合类
public class Demo {
public static void main(String[] args) {
String[] strArr = {"ab", "cd", "ef"};
for (String str : strArr) {
System.out.print(str + " ");
}
//output : ab cd ef
List<Integer> list = Arrays.asList(2, 4, 6);
for (int i : list) {
System.out.print(i + " ");
}
//output : 2 4 6
}
}
遍历List的时候需要增删元素则使用ListIterator类, 不能在上述for循环中增删,不然运行时会出错
List<String> list = new LinkedList<String>();
list.add("aa");
list.add("bb");
list.add("cc");
ListIterator<String> it = list.listIterator();
while (it.hasNext()) {
System.out.println(it.next());
it.add("ee");
}
System.out.println(list.size());//output : 6
注意 : 增强for循环中的变量时局部变量,值传递,并不是原集合某个元素对应的引用。
public static void main(String[] args) {
String[] strArr = {"ab", "cd", "ef"};
for (String str : strArr) {
str = "xxx";
}
System.out.println(strArr[0]); //output : ab
}
6.可变参数
public static void main(String[] args) {
show();
show("aa", "bb", "cc");
/*output:
是null吗?false 长度: 0
是null吗?false 长度: 3
aa bb cc
*/
}
//当方法中有多个参数时,可变参数要作为最后一个参数
private static void show(String... strings) {
System.out.println("是null吗?" + (strings==null) + " 长度: " + strings.length);
for (String str : strings) {
System.out.print(str + " ");
}
}
7.枚举类型
当需要用到一类范围内的固定常量的时候,考虑使用枚举(可以实现接口或者继承抽象类)
简单的枚举,及常用API使用
public enum Plant {
FLOWER, TREE, GRASS;
public static void main(String[] args) {
//values 方法获得所有值
Plant[] values = Plant.values();
for (Plant plant : values) {
System.out.println(plant);
}
//抛出参数异常
//Plant flower = Plant.valueOf("d");
//找到Plant.FLOWER
Plant flower = Plant.valueOf("FLOWER");
System.out.println(Plant.FLOWER == flower);//true
//打印枚举值的名字
System.out.println(flower.name());//FLOWER
//打印某个枚举值的位置
System.out.println(Plant.TREE.ordinal());//1
}
}
带构造器和方法的枚举 (枚举类型可用于switch语句)
public enum Plant {
FLOWER("花") {
@Override
public void eval() {
System.out.println("flower eval");
}
}, TREE("树") {
@Override
public void eval() {
System.out.println("tree eval");
}
};
private String cnName;
//枚举类的构造器必须为私有
private Plant(String cnName) {
this.cnName = cnName;
}
private String getCnName() {
return cnName;
}
abstract void eval();
private void operate() {
switch (this) {
case FLOWER:
System.out.println("operate flower");
break;
case TREE:
System.out.println("operate tree");
break;
default:
break;
}
}
}
若枚举类只含有一个值,则可作为单例使用
8.反射
把Java类的各个组成部分映射成一个个类,例如类的构造器、方法、成员、包等相关信息
定义一个Person对象
public class Person {
private String name="defaultName";
public Person() {
}
private Person(String name) {
this.name = name;
}
public String getName () {
return this.name;
}
private void showMsg (String msg, int i){
System.out.println(msg + " " +i);
}
public void show() {
System.out.println("my name is " + this.name);
}
}
反射构造器实例:
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
public class Demo {
public static void main(String[] args) throws ClassNotFoundException, SecurityException, NoSuchMethodException, IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException {
//获得Class的三种方式
// Class clazz = demo.Person.class;
// Class clazz = new Person().getClass();
Class clazz = Class.forName("demo.Person");
//获取空参的构造函数(getConstructor只能取到公有)
Constructor constructor = clazz.getConstructor(null);
Object obj = constructor.newInstance();
if(obj instanceof Person) {
Person p = (Person)obj;
p.show();
}
//获取带一个String类型参数的构造函数,要获得public以外的构造器要用getDeclaredConstructor
Constructor constructor2 = clazz.getDeclaredConstructor(String.class);
//设置取消java语言访问检查,私有的原本不能访问
constructor2.setAccessible(true);
Person p2 = (Person)constructor2.newInstance("newName");
p2.show();
}
}
反射方法实例:
public static void main(String[] args) throws ClassNotFoundException, SecurityException, NoSuchMethodException, IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException {
Class clazz = Class.forName("demo.Person");
Constructor constructor = clazz.getDeclaredConstructor(String.class);
constructor.setAccessible(true);
Person person = (Person)constructor.newInstance("newName");
//获取公有的空参方法
Method showMethod = clazz.getMethod("show", null);
//传入的第一个参数是调用该方法的实例,如果为null表示该方法是一个
//静态方法
showMethod.invoke(person, null);
//获取私有的方法,类似
Method showMsgMethod = clazz.getDeclaredMethod("showMsg", String.class, int.class);
showMsgMethod.setAccessible(true);
showMsgMethod.invoke(person, "hahah", 5);
}
反射成员属性:
public static void main(String[] args) throws ClassNotFoundException, SecurityException, NoSuchMethodException, IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException, NoSuchFieldException {
Class clazz = Class.forName("demo.Person");
Constructor constructor = clazz.getDeclaredConstructor(String.class);
constructor.setAccessible(true);
Person person = (Person)constructor.newInstance("newName");
// Field file = clazz.getField("name");
//类似获得私有的属性要用getDeclared**
Field nameField = clazz.getDeclaredField("name");
nameField.setAccessible(true);
nameField.set(person, "reflectName");
person.show();
}
其他细节:
1.可以通过 clazz.newInstance()创建对应实例,原理是反射获得无参构造器再去newInstance,所以一般保证有一个空参的构造器
2.启动java程序的main方法的参数是一个字符串数组,main(String[] args),通过反射方式来调用这个main方法时。按照JDK1.5的语法,整个数组是一个参数,但是按照JDK1.4的语法,数组中的每一个元素对应一个参数,当把一个字符串数组当做参数传给invoke方法时,(为了兼容1.4)会把数组拆分成若干个单独的参数。所以再给main方法传递参数的时候,不能使用这样的代码 mainMethod.invoke(null, new String[]{"xx","yy"}), 不然会提示参数错误,因为实际上传给args的参数是 字符串"xx",而不是字符串数组。 解决方法 invoke(null, (Object)new String[]{"xx","yy"})
或者 invoke(null, new Object[]{new String[]{"xx","yy"}})
分享到:
相关推荐
day002 JAVA语法基础-数组加强.doc
测试标准 - 绿色表示测试通过,代码有问题 - 红色表示测试 没有通过
1. 黑盒 2. 白 2. 白 1. 定义一个测试类 2. 定义测试方 3. 给方 4. 导入 junit 依赖环境 1. 可 2. 可 1. 可 2. 可 2
每日作业卷Java基础第二阶段第17天基础加强_XML传智播客.黑马程序员关卡1训练案例1训练描述:【讲义1.1.2:XML的作用】请写出XML的两个重要作用:
每日作业卷Java基础第二阶段第16天基础加强_注解_类加载器_动态代理传智播客.黑马程序员关卡1训练案例1训练描述:【讲义1.1:JUnit介绍】请使用一句话
day23_基础加强 day24_在线支付&JavaMail; day25_编码实战day01 day26_编码实战day02 day27_编码实战day02 day28_struts2基础 day29_struts2加强 day30_struts2拦截器&ognl;表达式 day31_struts2数据验证&...
java课程设计方案 设计目的与任务 本课程设计所要求达到的目的和任务:通过Java程序设计的一些重要理论基础来 实现"写字留痕"的"日历"和"记事本"的双重功能。并通过此次课程设计的训练,使学 生巩固和加深对Java这门...
实现步骤 :通过对原类文件继承,对原有方法功能的基础上,增强新的功能 使用场景: 不必改变原类,并且对原有功能进行加强的时候,就需要用装饰者模式 3. 适配器模式:(了解) 适配器类:...
java课程设计方案 设计目的与任务 本课程设计所要求达到的目的和任务:通过Java程序设计的一些重要理论基础来 实现"写字留痕"的"日历"和"记事本"的双重功能。并通过此次课程设计的训练,使学 生巩固和加深对Java这门...
检查电脑发现上面存在木马程序,木马程序利用了java的1个0day漏洞(漏洞的公布时间为2月1日)。 继续检查发现该木马已经在内网扩散了。 2023/6/4 网络安全培训全文共82页,当前为第9页。 事件二:斯诺登曝光美国棱镜...
ORACLE用户是学习ORACLE数据库中的基础知识,下面就介绍下类系统常用的默认ORACLE用户: 1. sys用户:超级用户,完全是个SYSDBA(管理数据库的人)。拥有dba,sysdba,sysoper等角色或权限。是oracle权限最高的用户,...