14_java之变量|参数|返回值|修饰符

 01java中的文档注释和制作

* A: 在eclipse使用时,可以配合文档注释,导出对类的说明文档,从而供其         他人阅读学习与使用。
    通过使用文档注释,将类或者方法进行注释用@简单标注基本信息。如@author 作者、@version代码版本、@param方法参数、@return方法返回值等。 

02eclipse生成jar包

03JAVA_HOME配置

04导入jar包

* A:   导入jar包:即把指定的jar包,加入到指项目中,提供给项目使用。
    导入jar包的过程是将jar包加入到项目的.classpath文件中去,让项目识别,便可以使用jar包中所有的.class文件类。
    以下是加入步骤:
    1:项目根文件夹下创建lib文件夹,用于同一管理所有的jar文件
    2:把jar文件复制到lib文件夹中
    3:右键点击jar文件,点击Build Path,选择Add to Build Path,此时查看项目根文件夹下的.classpath文件,发现新加入的jar包路径被配置到了该文件中。说明可以使用jar包中所有类了。
​
注意:
    Jar包加入后,必须Add to Build Path才能使用
    Jar包加入后,加入的类也必须导包,如果加入的类其包名与现有类包名相同,则视作在同一个包下。(不常见)

05不同修饰符使用细节

A: 常用来修饰类、方法、变量的修饰符如下:public 权限修饰符,公共访问, 类,方法,成员变量
   protected 权限修饰符,受保护访问, 方法,成员变量
   默认什么也不写 也是一种权限修饰符,默认访问, 类,方法,成员变量
   private 权限修饰符,私有访问, 方法,成员变量
   static 静态修饰符  方法,成员变量
   final 最终修饰符   类,方法,成员变量,局部变量
   abstract 抽象修饰符  类 ,方法
B: 不能同时使用的修饰符
    同时,abstract与private不能同时使用;
    同时,abstract与static不能同时使用;
    同时,abstract与final不能同时使用。
C: 修饰类能够使用的修饰符: 修饰类只能使用public、默认的、final、abstract关键字 使用最多的是 public关键字
    a:代码案例
        public class Demo {} //最常用的方式
        class Demo2{}
        public final class Demo3{}
        public abstract class Demo4{}
D:修饰成员变量能够使用的修饰符:
    public : 公共的
    protected : 受保护的
        : 默认的
    private :私有的
    final : 最终的
    static : 静态的
    使用最多的是 private
​
    a: 代码案例
        public int count = 100;
        protected int count2 = 100;
        int count3 = 100;
        private int count4 = 100; //最常用的方式
        public final int count5 = 100;
        public static int count6 = 100;
E:修饰构造方法能够使用的修饰符: public : 公共的 protected : 受保护的 : 默认的 private :私有的 使用最多的是 public

a:代码案例 public Demo(){} //最常用的方式 protected Demo(){} Demo(){} private Demo(){} ​ 修饰成员方法能够使用的修饰符: public : 公共的 protected : 受保护的 : 默认的 private :私有的 final : 最终的 static : 静态的 abstract : 抽象的 使用最多的是 public public void method1(){}//最常用的方式 protected void method2(){} void method3(){} private void method4(){} public final void method5(){} public static void method6(){}//最常用的方式 public abstract void method7();//最常用的方式

06局部变量和成员变量解析

* A:程序编译

数学工具类
public class MathTool {
    //求两个数的和的二倍
    public double sum2times(int number,int number2) {
        return (number+number2)*2;
    }
    //求两个数的积
    public double area(int number,int number2) {
        return number*number2;
    }
}
长方形类
public class CFX { //因为长与宽,在现实事物中属于事物的一部分,所以定义成员变量    private int chang;    private int kuan; public CFX(int chang, int kuan) { this.chang = chang; this.kuan = kuan; } //求长与宽的周长 public double zhouChang() { return (chang+kuan)*2; } //求长与宽的面积 public double mianJi() { return chang*kuan; } public int getChang() { return chang; } public void setChang(int chang) { this.chang = chang; } public int getKuan() { return kuan; } public void setKuan(int kuan) { this.kuan = kuan; } }

07类作为方法的参数

* A:类作为方法参数
    在编写程序中,会经常碰到调用的方法要接收的是一个类类型的情况,那么这时,要向方法中传入该类的对象。
    如下代码演示:
class Person{
            public void show(){
                System.out.println("show方法执行了");
            }
        }
        //测试类
        public class Test {
            public static void main(String[] args) {
                //创建Person对象
                Person p = new Person();
                //调用method方法
                method(p);
            }
            
        //定义一个方法method,用来接收一个Person对象,在方法中调用Person对象的show方法
        public static void method(Person p){
            p.show();
        }

08抽象类作为方法参数与返回值

* A:   抽象类作为方法参数
    今后开发中,抽象类作为方法参数的情况也很多见。当遇到方法参数为抽象类类型时,要传入一个实现抽象类所有抽象方法的子类对象。如下代码演示:
//抽象类
    abstract class Person{
        public abstract void show();
    }
    class Student extends Person{
        @Override
        public void show() {
            System.out.println("重写了show方法");
        }
    }
    //测试类
    public class Test {
        public static void main(String[] args) {
            //通过多态的方式,创建一个Person类型的变量,而这个对象实际是Student
            Person p = new Student();
            //调用method方法
            method(p);
        }
        
        //定义一个方法method,用来接收一个Person类型对象,在方法中调用Person对象的show方法
        public static void method(Person p){//抽象类作为参数
            //通过p变量调用show方法,这时实际调用的是Student对象中的show方法
            p.show();   
    }
    }

* B:抽象类作为方法返回值
    抽象类作为方法返回值的情况,也是有的,这时需要返回一个实现抽象类所有抽象方法的子类对象。如下代码演示:
    //抽象类
    abstract class Person{
        public abstract void show();
    }
    class Student extends Person{
        @Override
        public void show() {
            System.out.println("重写了show方法");
        }
    }
    //测试类
    public class Test {
        public static void main(String[] args) {
            //调用method方法,获取返回的Person对象
            Person p = method();
            //通过p变量调用show方法,这时实际调用的是Student对象中的show方法
            p.show();
        }
        
        //定义一个方法method,用来获取一个Person对象,在方法中完成Person对象的创建
        public static Person method(){
            Person p = new Student();
            return p;
        }
    }

09接口作为方法参数与返回值

* A:   接口作为方法参数
    接口作为方法参数的情况是很常见的,经常会碰到。当遇到方法参数为接口类型时,那么该方法要传入一个接口实现类对象。如下代码演示。
    //接口
    interface Smoke{
        public abstract void smoking();
    }
    class Student implements Smoke{
        @Override
        public void smoking() {
            System.out.println("课下吸口烟,赛过活神仙");
        }
    }
    //测试类
    public class Test {
        public static void main(String[] args) {
            //通过多态的方式,创建一个Smoke类型的变量,而这个对象实际是Student
            Smoke s = new Student();
            //调用method方法
            method(s);
        }
        
        //定义一个方法method,用来接收一个Smoke类型对象,在方法中调用Smoke对象的show方法
        public static void method(Smoke sm){//接口作为参数
            //通过sm变量调用smoking方法,这时实际调用的是Student对象中的smoking方法
            sm.smoking();
        }
    }
* B:   接口作为方法返回值
    接口作为方法返回值的情况,在后面的学习中会碰到。当遇到方法返回值是接口类型时,那么该方法需要返回一个接口实现类对象。如下代码演示。
​
    //接口
    interface Smoke{
        public abstract void smoking();
    }
    class Student implements Smoke{
        @Override
        public void smoking() {
            System.out.println("课下吸口烟,赛过活神仙");
        }
    }
    //测试类
    public class Test {
        public static void main(String[] args) {
            //调用method方法,获取返回的会吸烟的对象
            Smoke s = method();
            //通过s变量调用smoking方法,这时实际调用的是Student对象中的smoking方法
            s.smoking();
        }
        
        //定义一个方法method,用来获取一个具备吸烟功能的对象,并在方法中完成吸烟者的创建
        public static Smoke method(){
            Smoke sm = new Student();
            return sm;
        }
    }

10星级酒店案例

A: 根据“某五星级酒店,资金雄厚……都有自己的工作要做。”分析出,该题目中包含酒店,可以把它封装成类,多名员工。    
class 员工 {
         属性:姓名
    属性:工号
    方法:工作
    }
    class 厨师 extends 员工{}
    class 服务员 extends 员工{}
    class 经理 extends 员工 {
         属性:奖金
    }

员工的类型有经理、厨师、服务员,它们有共同的属性(姓名、工号、),经理额外属性(奖金)。
根据“向酒店中,增加多名员工(其中包含1名经理,1名厨师、2名服务员)”。分析出,要创建一个酒店对象,并添加4名员工到酒店对象的员工集合中。
  酒店员工集合添加新员工: 经理对象
  酒店员工集合添加新员工: 厨师对象
  酒店员工集合添加新员工: 服务员对象
  酒店员工集合添加新员工: 服务员对象
根据“获取酒店幸运员工”。分析出,从酒店员工集合随机得到一名员工对象。
  1. 从酒店员工集合长度范围内,随机产生一个随机数
  2. 使用该随机数作为集合的索引,返回该索引处对应的员工对象
根据“酒店开设VIP服务,酒店的厨师与服务员可以提供VIP服务。(厨师做菜加量、服务员给顾客倒酒)”。分析出,这是要增加一个VIP的接口,接口中提供个VIP服务的方法。让厨师与服务员实现该接口。

 interface VIP服务{
      抽象方法:服务
  }
  class 厨师 extends 员工 implements VIP服务{ 重写服务方法 }
  class 服务员 extends 员工 implements VIP服务{ 重写服务方法 }

B:

  VIP服务
  public interface VIP {
  public abstract void server();
  //服务
  } 

员工

/*员工:姓名 String 工号 String*/
public abstract class YuanGong { 
  // 成员变量
  private String xingMing;
  private String gongHao;
  // 构造方法
public YuanGong() {
  super();
}
public YuanGong(String xingMing, String gongHao) {
  super();
  this.xingMing = xingMing;
  this.gongHao = gongHao;
}
// 抽象方法
public abstract void work();
  // getters与setters
public String getXingMing() {
  return xingMing;
 }
public void setXingMing(String xingMing) {
  this.xingMing = xingMing;
}
public String getGongHao() {
  
return gongHao;
}
public void setGongHao(String gongHao) {
  this.gongHao = gongHao;
}
}

服务员

/*定义员工的子类 服务员类*/

public class FuWuYuan extends YuanGong implements VIP {
  public FuWuYuan() { 
  super(); } public FuWuYuan(String xingMing, String gongHao) {   super(xingMing, gongHao);
}
@Overridepublic void work() {   System.out.println("亲,全身心为您服务,记得给好评哦"); } @Overridepublic void server() { System.out.println("给顾客倒酒"); }}

经理

/*
经理在员工的基础上,添加了奖金成员
*/

public class JingLi extends YuanGong {
  private double jiangJin;   public JingLi() {   super(); } public JingLi(String xingMing, String gongHao, double jiangJin) {   super(xingMing, gongHao);   this.jiangJin = jiangJin; } public double getJiangJin() {
  return jiangJin; } public void setJiangJin(double jiangJin) {   this.jiangJin = jiangJin; } @Overridepublic void work() { System.out.println("哪个员工让顾客不满意,我扣谁钱"); }; }

厨师

/*
定义员工的子类 厨师类
*/ public class ChuShi extends YuanGong implements VIP{   public ChuShi() {
  super(); } public ChuShi(String xingMing, String gongHao) {   super(xingMing, gongHao); } @Overridepublic void work() {   System.out.println("我做饭,放心吃吧,包您满意"); } @Overridepublic void server() {   System.out.println("做菜加量加料"); } }

 

posted @ 2018-11-26 17:29  zhangqi0828  阅读(276)  评论(0编辑  收藏  举报