码迷,mamicode.com
首页 > 编程语言 > 详细

java - 第一阶段总结

时间:2016-12-22 00:08:00      阅读:261      评论:0      收藏:0      [点我收藏+]

标签:color   static   stat   断点   需要   帮助   rgs   ane   core   

    java - 第一阶段总结    

    递归    

递归:能不用就不用,因为效率极低

package over;
//递归
public class Fi {
    public static void main(String[] args) {
        int num = f(7);
        System.out.println(num);
    }
    public static int f(int n){
        if(n==1 || n==2){
            return 1;
        }else{
            return f(n-1)+f(n-2);
        }
    }
    /*
     * f7=f6(8)+f5(5)---------------------13
     *    f6=f5(5)+f4(3)------------------8
     *       f5=f4(3)+f3(2)---------------5
     *          f4=f3(2)+f2(1)------------3
     *             f3=f2(1)+f1(1)---------2
     *                f2------------------1
     *                f1------------------1
     */
}

不借助于第3个数,来交换两个数

package test.tang;

public class Test {
    public static void main(String[] args) {
        //------只适用于数字类型(整数类型),小数结果不准确
        int a=5,b=8;
        a = a+b; //a=13
        b = a-b; //b=5
        a = a-b; //a=8
        System.out.println("a="+a);
        System.out.println("b="+b);
    }
}

关于a++, ++a 的循环

        /*
         * 练习:
         * 1.声明整型变量a并赋值为0
         *     a=a++,输出a的值-------0
         * 2.声明整型变量b并赋值为0
         *     b=++b,输出b的值-------1
         * 3.声明整型变量c并赋值为0
         *     for(int i=1;i<=100;i++){
         *       c=c++;
         *     }
         *     System.out.println(c);
         * 4.声明整型变量d并赋值为0
         *     for(int i=1;i<=100;i++){
         *       d=++d;
         *     }
         *     System.out.println(d);
         */
        
        /*
        int a = 0;
        //1.记录++a的值1
        //2.a自增1变为1
        //3.将记录++a的值1赋值给a
        a = ++a;
        System.out.println(a);
        */
        
        /*
        int a = 0;
        //1.记录了a++的值0
        //2.a自增1变为1
        //3.将记录a++的值0赋值给a
        a = a++;
        System.out.println(a);
        */
        
        /*
        int a = 0;
        for(int i=1;i<=100;i++){
            a=++a;
        }
        System.out.println(a);
        */
        /*
         * a=++a;
         *     a=0
         * i=1 a=1
         * i=2 a=2
         * i=3 a=3
         * i=4 a=4
         * ...
         * i=100 a=100
         */
        
        /*
         * a=a++;
         *     a=0
         * i=1 a=0
         * i=2 a=0
         * i=3 a=0
         * i=4 a=0
         * ...
         * i=100 a=0
         */

注意的地方:

short s = 5;
s += 10; //系统自动帮助咱们做了强制类型转换
//s = s+10; //编译错误,必须自己强转

面向对象的设计思想:

1)对象、类:
  1.1)数据的封装--成员变量
  1.2)方法(操作数据)的封装


2.构造方法:给数据(成员变量)赋初值
  实例方法:操作对象的数据---与对象有关
  静态方法:操作参数的数据---与对象无关
  抽象方法:方法体没法写-----只能父类/接口中


3.继承:
  1)作用:代码复用
  2)很多类中有重复的代码时,设计父类来继承
    2.1)普通父类:没有抽象方法时
    2.2)抽象类:有抽象方法时
    2.3)接口:完全抽象方法时


4.设计规则:
  1)将公共的属性和行为,抽象到父类中
  2)所有子类方法的实现都一样-----普通方法
    所有子类方法的实现都不一样---抽象方法
  3)所有子类共有的,抽到父类中
    部分子类共有的,抽到接口中
    符合既是也是时,使用接口
    接口是对继承的单根性的扩展

 

1.何时需要Debug? 

  程序的运行结果,与你的预期结果不同时
  Debug的目的是找错误,而不是改错误


2.最早期调试就是打桩:
  System.out.println(???);


3.Debug调试步骤:
  1)先添加断点
  2)以调试模式来运行程序
  3)F5:单步调试(会进到方法中)
    F6:逐方法调试(不进到方法中)
    F7:结束方法的调试
    F8:直接跳到下一个断点
       若后面没有断点了则结束调试


  4.看变量
    添加监视

在记事本中自己顺Shoot游戏中的类的结构

 

    FlyingObject,Enemy,Award,
    Airplane,Bee,Bullet,Hero
    
    
abstract class FlyingObject{
  image,width,height,x,y
  abstract void step(){}
  abstract boolean outOfBounds(){}
  
}
interface Enemy{
  int getScore();
}
interface Award{
  int getType();
}
class Airplane extends FlyingObject implements Enemy{
  speed
  Airplane(){}
  boolean shootBy(){}
}
class Bee extends FlyingObject implements Award{
  xSpeed,ySpeed,awardType
  Bee(){}
  boolean shootBy(){}
}
class Bullet extends FlyingObject{
  speed
  Bullet(){}
}
class Hero extends FlyingObject{
  life,doubleFire,images,index
  Hero(){}
  Bullet[] shoot(){}
  boolean hit(){}
}

 

java - 第一阶段总结

标签:color   static   stat   断点   需要   帮助   rgs   ane   core   

原文地址:http://www.cnblogs.com/tangshengwei/p/6209508.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!