-------android培训、java培训、期待与您交流! ----------
第一节 eclipse使用技巧
一.概述:
1.eclipse是用开发java程序的工具。用它来提高我们开发代码的效率。
2.IDE:Itegrity Development Enviroment,集成开发环境
3.JavaEE:java Enterprise Edition:java企业版开发工具。
4.JMS:Java Message Service,Java消息服务,是一个Java平台中关于面向消息中间件的API,用于在两个应用程序间,或分布式系统中,发送消息,进行异步通信。
5.JMX:Java Management Extensions,Java管理扩展;是一个为应用程序、设备、系统植入管理功能的框架。
6.JNDI:Java Nameingand Directory Interface:Java命名和目录接口。
7.JDBC:Java Data Base Connectivity:Java数据库连接。
二.Eclipse使用和介绍
1.preferences(首选项) :
Java--->compiler--->在这里可以选择java以什么版本的jdk编译java程序。
2.切换工作间:
File---->Switch workspace--->other :选择在哪个盘下创建,若该盘没有你指定的目录则会在该盘下创建并加载工作间所需的配置信息。
3.设置快捷键:
Preferences--->General---->keys--->Content Assist--->设置快捷键。
4.perspective(透视图)和view(视图):
view:每个小窗口就是一个视图。
Perspective:若干个小窗口的集合就是透视图。
根据你对工作间的不同要求调出不同的透视图。
5.怎么查看变量值:
先在变量处打上断点,再右键Debug as 运行,这时eclipse就会调用Debug模式的透视图,再在变量处右键watch就能观察变量值了。
6.如何配制eclipse的编译与运行环境。
高版本的java可以运行低版本的javac编译的程序。
低版本java不能运行高版本javac编译的程序。
7.为java程序添加模板:${line_section} :代表原来的内容。 ${cursor} :光标悬停处。
Preferences---->Editor---->Templates
8.如何在eclipse导入已有工程。
File------>Import---->General---->Existing Projects into WorkSpace。
第二节 java5新特性 静态导入
一.静态导入概述:
1.import语句可以导入一个类或某个包中的所有类。
2.Import static 语句导入一个类中的所有静态成员。
二.可变参数:
特点:
1.只能出现在参数列表的最后。
2....位于变量类型和变量名之间,前后有无空格都可以。
3.调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中以数组的形式访问可变参数。
三.增强for循环。
语法:
For(type 变量名:集合变量名){.......}
注意事项:
迭代变量必须在()中定义!
集合变量可以是数组或实现了Iterable接口的集合类。
四.基本数据类型的自动拆箱与装箱:
自动装箱:Integer iobj = 13;
自动拆箱:System.out.println(iobj+12);
对于基本数据类型的说明:整数在-128 ~ 127之间的数,包装成Integer类型对象,会存入常量池中的缓存,再创建同一个对象的时候,会直接使用前一个已有的值,因为这些小数值使用的频率很高,所以这些数值需要如此的使用以优化内存。
享元模式(flyweight):
如果很多很小的对象,它们有很多相同的东西,那你就可以帮它们变成一个对象,把不同的东西,变为方法的参数,称之外部的状态,那些相同的东西就称位内部状态。
例:
26个字母,即使26个对象。当你word文档里输入他们时,有些相同的
字母只是出现的位置不一样。其实就是同一个对象。当一个char类型的字符被高度引用时,就可以把它封装成一个对象使用。
Integer i1 = Integer.valueOf(3);
Integer i2 = Integer.valueOf(3);
System.out.println(i1==i2);
这个程序运行结果为true。其中的道理就是利用了享元模式。
示例代码:
package javaenhance;
public class VarableParameter {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
System.out.println(add(2,3,5));
}
public static int add(int x,int...args){
int sum=x;
for(int i:args){
sum +=i;
}
return sum;
}
}
第三节 枚举
枚举是java1.5新增加的特性
为什么要有枚举:如果你要定义星期几或者性别变量,该怎么定义?假设用1-7分别表示星期一到星期日,但有人会把星期天定义成int num=0 这样别人引用时可能会把星期天定义成7造成代码出错
先用一个普通类来模拟枚举类是如何实现的:
示例代码:
package javaenhance;
public abstract class WeekDay1 {
public final static WeekDay1 sun = new WeekDay1(){
@Override
public WeekDay1 nextDay() {
// TODO Auto-generated method stub
return mon;
}
};
public final static WeekDay1 mon = new WeekDay1(){
@Override
public WeekDay1 nextDay() {
// TODO Auto-generated method stub
return sun;
}
};
/* public WeekDay nextDay(){
if(this ==sun)
return mon;
else
return sun;
}*/
public abstract WeekDay1 nextDay();
public String toString(){
return this==sun?"sun":"mon";
}
}
枚举的好处:枚举就是要让某个变量的取值只能是某几个固定的值,如果在编写程序时填写了非法的变量值,编译器就会报错,而普通的类无法实现这个功能。
怎么定义一个枚举:使用关键字enum。
枚举的特有方法:
String name(); 返回此枚举常量的名称,在其枚举声明中对其进行声明。
int ordinal(); 返回枚举常量的序数(它在枚举声明中的位置,其中初始常量序数为零)。
静态方法:
static Enum valueOf(String name) :返回一个枚举子类对象。
static Enum[] values(); 返回一个数组。可以把枚举里面对象当成数组操作。
实现带有构造方法的枚举:枚举类的构造方法必须是私有的,定义构造方法时要注意所有元素必须放在其他信息之前.
如要调用枚举的无参构造方法或者有参构造方法,则只需在枚举值后加()。括号内加入对应的变量即代表使用的是有参构造方法。无则代表使用的是无参构造方法。
示例代码:
package javaenhance;
public class EnumTest {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
WeekDay1 week = WeekDay1.mon;
System.out.println(week.nextDay());
WeekDay weekday = WeekDay.MON;
System.out.println(weekday);
System.out.println(WeekDay.valueOf("SUN"));
System.out.println(WeekDay.values().length);
}
//定义了一个枚举
public enum WeekDay{
SUN(),MON(2),TUS(3),FRI(4);
private WeekDay(){
System.out.println("first");
}
private WeekDay(int num){
System.out.println("second");
}
}
public enum TrafficLamp{
RED(30){
@Override
public TrafficLamp nextLamp() {
// TODO Auto-generated method stub
return GREEN;
}
}
,GREEN(45){
@Override
public TrafficLamp nextLamp() {
// TODO Auto-generated method stub
return YELLOW;
}
}
,YELLOW(5){
@Override
public TrafficLamp nextLamp() {
// TODO Auto-generated method stub
return RED;
}
};
public abstract TrafficLamp nextLamp();
private int time;
private TrafficLamp(int time){
this.time=time;
}
}
}