一、eclipse工具的使用

1. java代码的位置

1) 选择工作空间 workspace  选择一个文件夹存放程序(代码) 不要用中文和空格

2) 新建一个java 工程(Project)

3) 建包建类

2. 快捷键

alt + / :代码自动补齐,需要配置的

打开preferences(首选项), 搜keys,打开快捷键配置面板

搜 alt+/ ,取消绑定

搜 content assist ,取消原先的绑定,配置成alt+/

ctrl+1: 错误自动修复,注意,放行的红叉是可修复的,圆形的是不可修复的

导包的三种方式:

1)将类名敲完整,按下alt+/ 进行补齐,会自动导包

2) ctrl+1,修正错误

3) ctrl+shift+o 整理包,导入需要的包,去掉多余的导包语句

ctrl+shift+f : 代码格式化

管理透视图

ctrl+2,L  自动声明变量

shift+enter  光标直接进入下一行

ctrl+alt+方向键(向上向下)  复制行

alt+ 方向键(向上向下) 移动当前行

3. 断点调试

1) 可以对程序进行调试

在行的开头双击左键打断点,用debug方式来运行程序,程序就会停留在断点位置

F5 跳入(step into) 跳入方法内部  F6 跳过,让当前行运行  F7跳出返回上一层程序

resume 直接运行到下一个断点

2) 查看源代码建议使用断点调试的方式,注意当前运行环境需要包含源码

4. junit单元测试

1) 写一个java类,声明测试方式

修饰符为 public void ,

在方法前面加注解,(@Test)

此方法就可以进行测试了(交给junit运行)

2) 需要在测试方法前做初始化工作

写一个静态方法  public static void init()

在方法前加注解 @BeforeClass

3) 需要在测试后释放资源

写一个静态方法

在方法前加注解 @AfterClass

二、jdk5新特性

java 1995 诞生,版本: jdk1.0—jdk1.1 – jdk1.2 – jdk1.3 –jdk1.4 – 2005老虎版 jdk5.0 – jdk6 -- jdk7

1. 静态导入

1) 导入类的静态属性

import static java.lang.System.out;

out.println("haha");

2) 导入类的静态方法

import static java.lang.Math.*; // 导入Math类的所有静态成员

int num = abs(-10);

2. 基本数据类型的包装类

int --> Integer

byte --> Byte

short --> Short

long --> Long

char --> Character

double --> Double

float --> Float

boolean --> Boolean

1) Integer x = 1; x = x + 1;  经历了什么过程?装箱à拆箱à装箱

2) 为了优化,虚拟机为包装类提供了缓冲池, Integer池的大小 -128~127 一个字节的大小

3) String池

/*1. String s = "abc", 虚拟机首先会检查String池里有没有"abc"对象(通过equals方法)

// 如果有,直接返回引用,如果没有,会在池里创建一个“abc”对象,并返回引用

String s1 = "abc";

String s2 = "abc";

System.out.println(s1==s2); // result: true

*/

/* 2. String str = new String("abc"); 不管缓冲池是否有"abc", 都会在堆内存创建一个"abc"对象,返回引用

// 此时,负责检查并维护缓冲池,其实堆内存的对象是缓冲池中"abc"对象的一个拷贝

String s1 = new String("abc");

String s2 = new String("abc");

System.out.println(s1==s2); // result: false

*/

/* 3. String s = "a" + "b" + "c" + "d";  java编译器有个合并已知量的优化功能

// 在编译阶段就把"a" + "b" + "c" + "d" 合并为 ”abcd“

String s = "a" + "b" + "c" + "d";

//  String s = "abcd";

System.out.println(s=="abcd");// result: true

*/

/* 4.  String s1 = "a"; String s2 = "b"; String s3 = s1 + s2;

// String是常量,不能相加的,java如何实现的?

StringBuilder sb = new StringBuidler(s1);

sb.append(s2);

s3 = sb.toString();

也就是说实际上s3是方法返回的String对象

凡是方法返回的字符串对象都是在堆内存的,并且不负责维护缓冲池

*/

String s1 = "a";

String s2 = "b";

String s3 = s1 + s2; // 堆内存的对象

System.out.println(s3=="ab");// result: false

3. 增强for循环

1) 作用:

对存储对象的容器进行迭代

2)  jdk5以前怎么迭代

3) 增强for循环迭代数组

String [] arr = {"a", "b", "c"};   //数组的静态定义方式,只试用于数组首次定义的时候

// 传统方式

for(int i=0; i<arr.length; i++) {

// i依次表示数组的角标

String s = arr[i];

System.out.println(s);

}

System.out.println("-------------------------------------");

// 在jdk5中我们可以使用增强for循环迭代

// 增强for循环括号里写两个参数,第一个是声明一个变量,变量类型必须是数组元素的类型

// 第二个就是需要迭代的容器

// for循环会循环容器的length次, 每次都将容器的第n-1个元素赋值给声明的变量

for(String s : arr) {

// 循环体, 执行arr.length

// 每次都将arr中的第n-1个元素给s

System.out.println(s);   //

}

4) 单列集合 Collection

List list = new ArrayList();

list.add("aaa");

list.add("bbb");

list.add("ccc");

// 传统方式1

/* 1.获得迭代器

Iterator iter = list.iterator();

// 2.循环判断迭代器是否有下一个

while(iter.hasNext()) {

String str = (String) iter.next(); // 将迭代器的指针移向下一个,并将迭代当前指向的元素返回

System.out.println(str);

}

*/

// 传统方式2

for(Iterator iter=list.iterator(); iter.hasNext(); ) {

String s = (String) iter.next();

System.out.println(s);

}

System.out.println("--------------------------------");

// 增强for循环, 没有使用泛型的集合能不能使用增强for循环迭代?能

for(Object obj : list) {

String s =  (String) obj;

System.out.println(s);

}

5) 双列集合 Map

Map map = new HashMap();

map.put("a", "aaa");

map.put("b", "bbb");

map.put("c", "ccc");

// 传统方式迭代1

// 1. 获得所有的key

Set keys = map.keySet();

// 2.迭代keys获得所有的key

Iterator iter = keys.iterator();

while(iter.hasNext()) {

String key = (String) iter.next(); // a b c

// 3.根据key获得对应的value

String value = (String) map.get(key);

System.out.println(key + "=" + value);

}

System.out.println("---------------------------------");

// 传统方式2,必须掌握这种方式

// 1.获得所有的键值对Entry对象

Set entrys = map.entrySet();

// 2.迭代出所有的entry

iter = entrys.iterator();

while(iter.hasNext()) {

Map.Entry entry = (Entry) iter.next();

// 分别获得key和value

String key = (String) entry.getKey();

String value = (String) entry.getValue();

System.out.println(key + "=" + value);

}

System.out.println("-------------------------------------");

System.out.println("增强for循环迭代,");

// 增强for循环迭代,

// 原则上map集合是无法使用增强for循环来迭代的,

// 因为增强for循环只能针对实现了Iterable接口的集合进行迭代

// Iterable是jdk5中新定义的接口,就一个方法iterator方法

// 只有实现了Iterable接口的类,才能保证一定有iterator方法

// java有这样的限定是因为增强for循环内部还是用迭代器实现的

// 而实际上,我们可以通过某种方式来使用增强for循环

for(Object obj : map.entrySet()) {

// obj 依次表示Entry

Map.Entry entry = (Entry) obj;

System.out.println(entry.getKey() + "=" + entry.getValue());

}

6)集合迭代注意问题

// 在使用迭代器迭代集合的过程中,不能对集合进行增删操作

@Test

public void test4() {

List list = new ArrayList();

list.add("wangwu");

list.add("zhangsan");

list.add("lisi");

Iterator iter = list.iterator();

while(iter.hasNext()) {

String name = (String) iter.next();

if("wangwu".equals(name)) {

// 从集合中删掉

//list.remove(name);

// 迭代过程中删除元素需要调用迭代器的方法

iter.remove();    // 删除我迭代的集合被我迭代的最后一个元素

}

}

// 1 2 4

System.out.println(list.size());

}

@Test

public void test5() {

List list = new ArrayList();

list.add("aa");

list.add("bb");

// 使用ListIterator迭代器

ListIterator listIterator = list.listIterator();

while(listIterator.hasNext()) {

listIterator.next();

// 迭代过程中增加元素

listIterator.add("cc");

}

System.out.println(list.size());

}

7) 增强for循环注意问题

//在使用增强for循环时,不能对元素进行赋值

int[] arr = {1,2,3};

for(int num : arr) {

num = 0;

}

System.out.println(arr[1]);

4. 可变参数

1) jdk5中方法的形参可以定义为可变参数,传入实参个数可变

// 设计一个方法求n个数的和

public static int getSum(int... arr) {

// 可变参数在方法中仍被看做一个数组

int sum = 0;

for(int num : arr)

sum += num;

return sum;

}

2)Arrays.asList为例演示传入不同参数的情况

// list长度为3

List list = Arrays.asList("a","b","c");

// list长度为1, 因为考虑1.4语法

String[] arr = {"a","b","c"};

List list = Arrays.asList(arr);

// 同时符合1.4和1.5的语法,此时会优先考虑1.4的语法

// 原因是有了新功能要保证以前的代码不出错,向后兼容

// 现在就需要将arr作为一个元素存入集合

Object obj = arr;

List list2 = Arrays.asList(obj);   // 此时只符合1.5的语法,不符合1.4的语法,没有歧义

List list3 = Arrays.asList(new Object[]{arr});   // 优先考虑1.4,所以数组会拆开

//System.out.println(list3.size());

// 基本数据类型数组只符合1.5的语法

int[] nums = {1,2,3};

list = Arrays.asList(nums);

System.out.println(list.size());

5. 枚举

问题:对象的某个属性的值不能是任意的,必须为固定的一组取值其中的某一个

解决办法:

1)    在setGrade方法中做判断,不符合格式要求就抛出异常

2)    直接限定用户的选择,通过自定义类模拟枚举的方式来限定用户的输入

写一个Grade类,私有构造函数,对外提供5个静态的常量表示类的实例

3)        jdk5中新定义了枚举类型,专门用于解决此类问题

4)        枚举就是一个特殊的java类,可以定义属性、方法、构造函数、实现接口、继承类

//枚举类就是一个java类,也可以声明属性,方法,构造函数

public enum Grade4 {

A("90-100"),B("80-89"),C("70-79"),D("60-69"),E("0-59");

private String value;

private Grade4(String value) {

this.value = value;

}

public String getValue() {

return value;

}

}

//枚举类就是一个java类, 也可以继承抽象和实现接口

public enum Grade5 {

// 抽象类不能创建实例对象

A("90-100"){

// new了一个Grade5的子类实例

public String toLocaleString() {

return "优";

}

}

,B("80-89"){

// new了一个Grade5的子类实例

public String toLocaleString() {

return "良";

}

}

,C("70-79"){

// new了一个Grade5的子类实例

public String toLocaleString() {

return "中";

}

}

,D("60-69"){

// new了一个Grade5的子类实例

public String toLocaleString() {

return "差";

}

}

,E("0-59"){

// new了一个Grade5的子类实例

public String toLocaleString() {

return "不及格";

}

};

private String value;

private Grade5(String value) {

this.value = value;

}

public String getValue() {

return value;

}

// 对外提供一个方法,返回枚举的本地信息

// 一个方法不知道如何实现,可以定义为抽象的

public abstract String toLocaleString();

}

l  练习:请编写一个关于星期几的枚举WeekDay,要求:

•    枚举值:Mon,Tue,Wed,Thu,Fri,Sat,Sun  星期一。。。。星期日

•    该枚举要有一个方法,调用该方法返回中文格式的星期。

6. 反射

1)java代码的阶段

一段java代码在程序运行期间会经历三个阶段: source-->class-->runtime

2) Class 对象

在java中用一个Class对象来表示一个java类的class阶段

Class对象封装了一个java类中定义的成员变量、成员方法、构造方法、类名、包名等

获得class对象的三种方式和区别

// 1. 根据给定的类名来获得  用于类加载

String classname = "cn.itcast.reflect.Person";   // 来自配置文件

Class clazz = Class.forName(classname);   // 此对象代表Person.class

// 2. 如果拿到了对象,不知道是什么类型   用于获得对象的类型

Object obj = new Person();

Class clazz1 = obj.getClass();  // 获得对象具体的类型

// 3. 如果是明确地获得某个类的Class对象  主要用于传参

Class clazz2 = Person.class;

// 在java中所有的类型都会对应一个Class对象 int Integer

Class intClazz = int.class;

Class intarrClazz = int[].class;

Class voidClazz = void.class;

3)反射

反射就是获得一个java类的各个组成部分

// 反射类的成员方法

Class clazz = Person.class;

Method method = clazz.getMethod(methodName, new Class[]{paramClazz1, paramClazz2});

method.invoke();

// 反射类的构造函数

Constructor con = clazz.getConstructor(new Class[]{paramClazz1, paramClazz2,...})

con.newInstance(params...)

// 反射类的属性

Field field = clazz.getField(fieldName);

field.setAccessible(true);

field.setObject(value);

4) 反射用在哪里

到底框架是什么?  框架就是将开发中大量重复的代码集中起来写个通用的程序

框架就是用反射来实现的

框架需要现在的类调用将来写的类

框架是将来的程序员调用的,框架不能实现完整的功能,框架只是一些一些通用的代码

框架要运行一定会依赖将来写的类

现在写的类要调用将来写的类,我们先针对接口进行调用,将来的类需要实现接口,那么方法就固定了

但是将来写的类的类名我们无法获知,这时就需要调用者通过配置文件告诉框架具体的类名

7. 泛型

1) 泛型是一种可变化的类型

类型不确定,需要调用者来指定

2) 用途:

一个类的多个成员方法用到的参数类型或返回值类型都是未知的类型,但又需要是同一个类型,就可将方法的

参数类型定义为泛型,此泛型必须在类上先予以声明才能在方法中使用

一个方法的多个参数和返回值需要是同一个类型,也可以用泛型来解决,在返回值前面声明泛型

3. 泛型的基本概念

以List<E>为例:<>念着typeof 例, List<String> 就是 List typeof String

List<E>中的E称为类型参数变量     方法定义参数形式参数

List<Integer>中的Integer称为实际类型参数

整个List<E>称为泛型类型   GenericType

整个List<Integer>称为参数化的类型

4. 泛型的使用

1)使用带泛型的类时,在创建对象时可以为泛型指定实际类型参数,指定的具体类型相当于给泛型传参

2)子类在继承父类的时候,可以为父类定义的泛型指定实际类型参数

class B<T>

class A extends B<String>

通过子类A获得的父类类型就是一个参数化的类型

3)调用方法时传入参数的具体类型将作为方法中泛型的实际类型

01-java基础加强,eclipse工具使用,快捷键,断点调试,单元测试,jdk5新特性,增强for循环,集合map,list,可变参数,枚举,反射,泛型相关推荐

  1. java基础-Idea开发工具介绍

    java基础-Idea开发工具介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 之前给大家介绍过一款Java的IDE叫eclipse,有些功能用起来不是很得心应手,尤其是在导报的 ...

  2. 01.Java基础语法

    目录 01.Java基础语法 一,环境搭建 1,Java体系与特点 2,Java跨平台原理 2.1 Java虚拟机(JVM) 2.2 垃圾回收器(GC) 2.3 Java SE组成概念图 2.4 JD ...

  3. 【Java学习笔记之二十八】深入了解Java8新特性

    前言: Java 8 已经发布很久了,很多报道表明java 8 是一次重大的版本升级.在Java Code Geeks上已经有很多介绍Java 8新特性的文章,例如Playing with Java ...

  4. Java学习第五天,增强for,方法重载,可变参数,数组定义及稀疏数组。

    增强for,方法重载,可变参数,数组定义及稀疏数组. 增强for package com.hyb.base;public class for_strengthen {public static voi ...

  5. Java基础(二)——IDEA快捷键、类和对象、三大特征、构造方法、对象比较、抽象类、接口、模拟发红包

    IDEA常用快捷键 快捷键 功能 Alt+回车 导入包,自动修正 Ctrl+N 查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L 格式化代码 Ctrl+Alt+O 优化导入的类和包 A ...

  6. java基础之idea工具使用

    一.idea 的基础设置 1. 配置jdk 2. 隐藏项目中的".idea"和"*.iml"文件 3. 创建类及运行代码方法 4. 修改编写代码的字体和大小 5 ...

  7. Java框架tk_TKmybatis的框架介绍和原理分析及Mybatis新特性

    tkmybatis是在mybatis框架的基础上提供了很多工具,让开发更加高效,下面来看看这个框架的基本使用,后面会对相关源码进行分析,感兴趣的同学可以看一下,挺不错的一个工具 实现对员工表的增删改查 ...

  8. java for each 的源_Java JDK1.5的新特性之for-each循环的底层原理

    今天给大家分享一下for-each循环的底层原理,故事还得从字节码反汇编和反编译说起... 首先看一下Java JDK1.5的新特性 泛型: ... for-each. ... 自动拆箱和装箱功能 . ...

  9. Java基础---键盘录入工具(Scanner类)

    键盘录入工具(Scanner类) 由jdk的类库提供,在类库中的java.util包下,键盘录入步骤是: 1.导包:import 包名.类名 即 import java.util.Scanner; 2 ...

最新文章

  1. secret-galaxy-300 Replace(印象深刻) 寒假逆向生涯(8/100)
  2. Python3中提示:no module named 'wxpy'
  3. 2005年度国产空间信息系统软件测评工作圆满结束
  4. 关于ORM的一些外文资料
  5. jdk12连接mysql_使用基于JDK12版本的JDBC读取数据库中的数据在网页(jsp)表示出来...
  6. CentOS6.5下安装mfs分布式存储(转)
  7. IAR8.3 STM8安装过程
  8. 毕业论文 Word 排版技巧
  9. CCF-CSP真题《202209-3—防疫大数据》思路+python题解
  10. 2019 ICPC西安邀请赛 游记
  11. 在word中怎么实现奇数页页眉用本章标题,偶数页用论文标题?
  12. pause、who、whos命令,Matlab中存储实数的形式总结,format两个命令
  13. 自由职业者:提高效率的6个简单方法
  14. 为何水在地球上几亿年都不过期,装进瓶子却很快过期科学家解惑
  15. 使用VMWare虚拟机创建CentOS版本的Linux学习环境(每一步都有截图与说明)
  16. 卡牌系统psv游戏推荐_《天下HD》荣获App Store首页双位推荐 全新情缘系统盘活游戏社交...
  17. 《联想本有更好的路走》《杨元庆会不会掉队》《少帅杨元庆》
  18. 命令行执行sql脚本
  19. 京东商业提升事业部广告质量部招聘2023届算法实习生
  20. VmwareWorkstation 16安装win7 32位镜像

热门文章

  1. wxWidgets:wxPanel类用法
  2. boost::test模块自定义用户异常转换器注册表的单元测试
  3. boost::hana::hash用法的测试程序
  4. boost::undirected_dfs用法的测试程序
  5. boost::geometry::coordinate_type用法的测试程序
  6. boost::callable_traits移除const成员的测试程序
  7. DCMTK:类DVPSIPCClient的示例消息服务器
  8. DCMTK:从DICOM封装的PDF存储对象中提取PDF文件
  9. VTK:图片之ImageSliceMapper
  10. VTK:几何对象之EarthSource