zoukankan      html  css  js  c++  java
  • Java基础程序与面向对象

    首先,我们需要了解和知道一些Java的基本概念:

      程序编译过程:.java文件会通过编译器--被编译成一个. class字节码文件---再由虚拟机运行.class文件解释运行Java程序。

      编码规范:可以考虑遵循阿里巴巴的开发手册。

      类:作为一个加载程序逻辑的容器,程序逻辑定义了应用程序的行为。Java程序的基本单位
      包:确保类名的唯一性。
       其次了解编程的基础:
    控制程序流程:
       选择结构语句:
                      if语句:if(boolean表达式){ 语句1:真语句 }else{ 语句2:假语句 }
                      switch语句:switch(某个值)
              case 值:语句体; break;
              case 值: 语句体;break;
              default 值 : 语句体;break;
          Case值可以为:char、byte、short、int、String、枚举常量等
     
      循环语句结构:
                      for(语句一;语句二;语句四){语句三}
                      while(boolean表达式){循环体}
                      do(boolean表达式)while(循环体)
            
         增强foreach循环:
                  格式:for(元素数据类型变量x : 数组或者collection集合){
                          使用变量即可,该变量就是元素; 
           }  
          //    区别:for循环结束即注销/while循环结束可调用值作统计。
                 break 中断循环     
                 continue 跳过本次循环
                 return    返回值 结束方法,后面内容不编译//返回负数,值不存在
     
    运算符:算术运算符:+ ,-, *, /, %,++(自增+1), --(自减-1) 
                 -------字符+整型,先用ASCII码表算出字符在表中对应的整型,再相加,输出整型值。
                   赋值运算符:  = 、+= 、-= 、*= 、/= 、%=             
                   关系运算符::>、<、>=、<=、==、!=
                   逻辑运算符:! 、&、|、^、&&、||                 
                   单&时,左边无论真假,右边都进行运算   双&&有短路效果,当左边FALSE时,中断,右边不判断。
                          &逻辑与:有false则false   //   | 逻辑或:有true则true  //    ^ 逻辑异或:相同为false,不同为true。
            位运算符:&("and")、|("or")、^("xor")、~("not")、>>、<<、>>>       ---------------位运算,先把数据转换为二进制。 
       了解Java的数据类型
    数据类型:4类8种【java语言强类型语言,定义分配了大小存取空间】
       基本型   整型【byte、short、int[默认值]、long】 1字节 2字节  4字节  8字节    且byte类型的取值范围在 -128~127
            Java中整型的范围与运行Java代码的机器无关,且解决了程序移植问题。-------在C和C++中int和Long类型的大小与目标平台相关。
            十六进制前缀加0x或者0X、二进制前加0b或者0B。   
     
                       浮点型【double[默认值]、float】        8字节  4字节                 ------单精度浮点数加F/f
            浮点数值不适合用于无法接受舍入误差的金融计算中,即System.out.printf(2.0-1.1)结果为0.8999999.
              原因是:浮点数值采用二进制系统表示。而二进制系统无法准确的表示分数的1/10,就好比十进制无法精确的表示1/3---推荐使用BigDecimal类
        
         当整型和浮点型不能满足需求时,java.math包中提供了BigInteger 提供任意精度的整数运算-----BigDecimal 提供任意精度的浮点数运算。
            这两个类可以处理任意长度数字序列的数值。使用静态方法ValueOf()方法能将普通数值转换为大数值,且不能用运算符处理大数据,有具体方法。     
     
                       字符型【char】  2字节    --------表示Unicode编码的字符单元的字符类型                    
                       布尔型【boolean】          1字节    两个值 FALSE 和  TRUE 
        
    变量的类型转换:  自动转换:{byte,short,char-int-long-float-double 从小到大转换} 
                                    {byte,short,char相互不转换,参与运算符首先转换为int类型}        ----- boolean不参加转换
                      强制转换:{【二者不兼容】【目标类型范围小于源类型】}        --------大转小--损失精度
                         格式:目标类型 变量名=(目标类型) 值   -----后期Object类型转换用得多
     
        变量类型默认值: 引用类型的变量是默认值为 null , 数组引用类型的变量的默认值为 null,局部变量没有默认值,需手动初始化。
    引用型  :类【class】、接口【interface】、数组、枚举【enum】、注解【annotation】
      
      String类型:不可变字符串,Unicode字符序列,Java没有内置的字符串类型,而是在标准的Java类库中提供了一个预定义类--String,用双引号扩起来。
          字符串存在于方法区的常量池中,所有字符串共享
          而当使用+运算符时,每创建一个新的字符串对象。
          ==只能比较字符串所在的位置是否相同,而equals比较两个字符串常量的值是否相等。
         StringBuffer类:为了解决大量拼接字符串时产生很多中间对象问题而提供的一个类,效率低,但采用多线程的方式执行添加和删除字符操作。
        StringBuilder类:作用相同,效率高。
        Java中引入字符常量池概念即创建一个字符串时,首先会检查池中是否有值相同的字符串对象,如果有就直接返回引用,不会创建字符串对象;
            如果没有则新建字符串对象,返回对象引用,并且将新创建的对象放入池中。但是,通过new方法创建的String对象是不检查字符串常量池的,而是直接在堆中创建新对象,也不会把对象放入池中
     
      数组:一种数据结构,用来存储同一类型值的集合。初始化值为0或者null。
          多维数组:就是一维数组的组合。 arr[行][列]。   数据类型[][] 数组名 = new 数据类型[][]{{元素...}{元素...}};
          数组遍历:【依次访问数组中的每个元素】
             数组排序:冒泡排序 //逆序、最值、排序、查索引值
     
      类(class):由类构造(construct)对象的过程称为创建类的实例(instance)。
              对象中的的数据称为实例域--属性,
              操作数据的过程称为方法---行为。
              对象的状态--对象保存着的当前特征信息--当施加那些方式时,对象如何响应?
        类之间的关系:
            依赖:("uses-a"):一个类的方法操控另一个类的对象。
            聚合:("has-a"):类A的对象包含类B的对象。
            继承:("is-a"):儿子与爸爸的关系--财产继承。
         构造器:【方法名和类名相同】
                            【方法名前面没有返回值类型的声明】
               【在方法中不能使用return语句返回一个值】
               【this(....)调用本类的构造方法/super(.....)调用父类的构造方法 //必须出现在第一条语句上】
               【构造方法的重载,通常用public来修饰】
        
        方法:修饰符 返回值类型 方法名(参数类型 参数名1....){  方法体语句;return 返回值;}
                  方法的重写:子类中出现和父类方法中一模一样的方法声明,也叫方法覆盖。//当子类需要父类的功能也要有自己的特有功能,可以考虑重写,权限不能低。
                  方法的重载:一个程序中定义多个名称相同的方法,但是参数的类型和个数/顺序必须不同。与返回值无关。
                  方法的递归:一个方法的内部调用自身的过程,且必须有结束条件。
     
       
          
    This关键字:代表本类中的对象引用,在方法中访问对象的其他成员。
      在使用this调用类的构造方法应注意
        【只能在构造方法中使用this调用其他构造方法,不能在成员方法中使用。】
        【在构造方法中。使用this调用构造方法语句必须位于第一行,只能出现一次】
        【不能在一个类的两个构造方法中使用this互相调用】
     
    super关键字:代表父类的对象引用,用于访问父类的成员。
      【使用关键字super调用父类的成员变量和成员方法】super.成员变量/super.成员方法(参数)
      【使用关键字调用父类的构造方法】super(参数);
     
    Static关键字【状态修饰符】
      Static关键字修饰类的成员。//类名.静态名
        静态变量:静态变量被所有实例共享,都可以通过“类名.变量名”来访问。
        静态方法:可以通过“类名.方法名”来访问。【静态方法只能访问static修饰的成员变量和方法】
        静态代码块:只执行一次,通常使用静态代码块对类的成员变量初始化。
     
    Final关键字【状态修饰符】
      修饰类、变量、方法。
        【修饰的类不能被继承,不能派生子类】
        【修饰的方法不能被子类重写,】
        【修饰的变量是常量(自定义常量/字面值常量)】
     
       继承:【格式:子类extends父类】
        【单继承:一个类只能有一个直接父类】
        【多个类可以继承一个父类】
        【多层继承,继承爷爷类】
        【让类与类产生关系,是多态的前提】
        【弊端:类之间的耦合性增强】
    继承的注意事项 :  【子类中所有的构造方法都会默认先访问父类中无参的构造方法】
               【父类没有无参构造方法?a.子类通过super去明确调用带参构造,b.通过this调用本身其他构造,但有一个一定会访问父类构造】  
               【子类构造方法的首句默认为super();】
               【子类不能继承父类的构造方法,可以通过super关键字访问父类构造方法】
               【子类权限不能大于父类,成员变量名相同,采用就近原则】 
               【子类只能继承父类所有非私有的的成员(成员变量和成员方法)】
               【重写父类方法:具有相同的方法名、参数列表以及返回值类型。】 
             【子类调用父子类同名的方法或变量,默认先调用子类的方法或变量】
     
    多态: 同一个对象在不同时刻体现出来的不同状态。
        前提:【要有继承或实现关系】
                   【要有方法重写】
                   【要有父类或父类接口引用指向子类对象 //父类 标识符 = new 子类()】
      具体类多态【class Fu{ }   class Zi extends Fu{ }    Fu f = new Zi()】
      抽象类多态【abstract class Fu{ }   class Zi extends Fu{ }    Fu f = new Zi()】
      接口类多态【interface Fu{ }   class Zi implementsFu{ }     Fu f = new Zi()】
        多态中成员访问特点【成员变量   编译看左边 , 运行看左边】
                                         【构造方法  子类的构造方法都会默认访问父类的构造方法,对父类数据进行初始化】
                                         【成员方法   编译看左边 , 运行看右边//方法存在覆盖重写】
                                         【静态方法   编译看左边 , 运行看左边//静态随类加载,不做改变】
      对象中转型问题[多态中]
                【向下转型】把父类的引用强制转换为子类的引用。子类  z = (子类) f ;//该f 是能转换为子类的
                【向上转型】F类  f = new 子类();
      同一个方法中,这种由于参数型不同的而导致执行效果各异。
                允许使用一个父类类型的变量来引用一个子类类型的对象。
     
    抽象:用abstract关键字修饰,把不具有具体的功能成为抽象的功能。
      抽象方法:【格式:public abstract void 方法名()】定义方法时没有方法体,不包含方法体的方法为抽象方法,】
      抽象类:【格式: abstract class 类名()】包含抽象方法的类必须声明抽象类,但抽象类可以不包含抽象方法。】
                    【抽象类不可以被实例化,抽象方法没有方法体则不能被调用】
    抽象类的子类:      
        【重写所有的抽象方法,这个时候子类是个具体的类】
        【如果不想重写所有的抽象方法,该子类必须为抽象类】
        【通过多态的方式实现实例化】
     
    以上内容若有错误,大家多多指正。
     
  • 相关阅读:
    面向报文(UDP)和面向字节流(TCP)的区别
    c++ 字符串和数字拼接
    OpenGL中着色器,渲染管线,光栅化
    阅读计划
    课堂测试
    多态与异常处理
    《大道至简》第七八章读后感
    继承与接口课堂作业
    《大道至简》第六章读后感
    随机数组
  • 原文地址:https://www.cnblogs.com/Tanggula-pioneer/p/11731895.html
Copyright © 2011-2022 走看看