Java基础程序与面向对象

2019-10-25 07:09:30来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

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 类名()】包含抽象方法的类必须声明抽象类,但抽象类可以不包含抽象方法。】                 【抽象类不可以被实例化,抽象方法没有方法体则不能被调用】 抽象类的子类:           【重写所有的抽象方法,这个时候子类是个具体的类】     【如果不想重写所有的抽象方法,该子类必须为抽象类】     【通过多态的方式实现实例化】   以上内容若有错误,大家多多指正。  

原文链接:https://www.cnblogs.com/Tanggula-pioneer/p/11731895.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:java-day12

下一篇:springboot使用idea打jar包