面向对象之继承

1.继承

继承的概念:(继承关系:extends)
 	将一些类共性的内容抽取出来,单独定义在一个独立的类中,让这个独立的类和这多个类产生一种关系
        
继承的好处:
	1)提高了代码的复用性
    2)提高了代码的维护性
    3)类与类产生的继承关系,是多态的前提条件!
   
        
 继承的格式
   	class 父类名{}
   
   	class 子类名 extends 父类名{}
  

继承的特点:
 		1)在Java中,继承(类与类之间),只支持单继承,不支持多继承!
 			在有的语言里面支持多继承: 子类 extends 父类1,父类2{}...
 		2)虽然Java中,继承(类与类之间)不支持多继承,但是可以多层继承!
 

继承中的注意事项:
  
 	1)子类继承父类,不能继承父类的私有的成员(成员变量,成员方法),
  原因:被私有修饰的外界访问不到,但是通过公共的访问方法来间接访问
   2)子类继承父类,不能够继承父类的构造方法,但是可以通过super关键字,来间接访问


 加入继承关系之后,类的成员访问问题:
  分为两种情况:
  		1)子类中和父类中成员变量名称不一致的情况:  比较简单的,分别访问即可!
  		2)子类中和父类中成员变量名称一致的情况:
  			遵循"就近原则"
  		 2.1)先在子类的局部位置找,如果存在,就使用;
  		 2.2)如果局部位置没有,那么就在子类的成员位置中找,如果有,就使用;
  		 2.3)如果子类的成员位置中没有,那么直接在父类的成员位置找,有就使用;
  		 2.4)如果父类的成员位置都没有的,那么就报错了,不存在这个变量!
             
             
Java中的开发原则:
   		低耦合,高内聚
  		耦合:类与类之间的关系,越少越好! (在开发中:降低程序间的耦合性---->Spring框架:IOC思想:控制反转)
  		内聚:完成某个事情能力:在一个类中能完成的,尽量一个类中完成!(执行力)
  

2.子类继承父类,关于构造方法的问题

	子类不能继承父类的构造方法,但是可以通过super间接访问父类的构造方法
  	子类的所有构造方法默认访问父类的无参构造方法!
    构造方法的目的:就是为了数据初始化 
        
        
为什么要访问父类的无参构造方法?
  	由于存在继承关系,创建的是子类对象,对子类初始化的时候(执行构造方法),可能会用到父类的数据,必须要让父类先进行初始化(先执行父类的构造方法),父类初始化完毕了,才是子类初始化(分层初始化!)

        注意:每一个子类的构造方法中的第一句话
                    默认存在super() ; 可以不写(隐藏的)

        super:代表父类的空间标识(代表父类对象的地址值引用)	

3.父类中没有提供无参构造方法的原因及解决办法

注意事项:
  		子类的构造方法默认访问父类的无参,
  						
那么如果父类中没有提供无参构造方法?会怎么办
      会编译报错,因为父类有存在有参构造方法,系统不会提供无参的,又由于子类的所有构造
      方法默认访问父类的无参,所以报错了!
    
 如何解决呢?
	 1)手动给出父类的无参构造方法
  	 2)可以让子类的所有构造方法,默认访问父类的有参
 		在子类的构造方法的第一句话:super(xxx)
 	 	子类中所有构造方法的一个只要能够让父类初始化即可!
  	 3)通过子类的有参构造方法,访问this()本类的无参构造方法,在通过本类的无参构造方法
  访问父类的有参构造(让父类先进行初始化)
  

4.this和super的区别

this:代表当前类的对象地址值引用
super:代表父类的空间标识(父类对象的地址值引用)
 
访问的区别
   		this.成员变量;访问的当期类的成员变量
   		super.成员变量;访问的父类的成员变量
   
   		this.成员方法名() ;访问的是否当前类的成员方法
   		super.成员方法名() ;访问的是父类的成员方法
   
   		this() :访问的是本类无参构造方法
  		this(xxx):访问的本类的有参构造方法
 
 		super():访问的是父类的无参构造方法
 		super(xxx):访问的父类的有参构造方法
   
 关于继承中构造方法关系问题:
  	子类的所有构造方法默认访问父类的无参,需要让父类先进行数据初始化,才是子类进行数据初始化!

5.优先级问题

1)代码块的优先级问题
 	静态代码块只执行一次,> 构造代码块 > 构造方法
  运行程序的试试,jvm检查语法结构,有父子关系,先加载父类,再是子类,static相关 先进内存
2)继承中:分层初始化
      优先让父类初始化(执行父类的构造方法)---->子类可能用到父类的数据,所以父类先初始化,
      然后子类初始化(执行子类的构造方法)

6.继承中的成员方法关系问题

1)成员方法名不一致的情况:分别访问即可! (比较简单)
2)成员方法名称一致的情况:
	先在子类中找是否存在这个方法,如果存在,就使用,会将父类的方法覆盖掉(等会讲方法重写)
 	如果子类找不到这个方法,就在父类中找,有就使用;
  	如果父类中都找不到,就报错了!

7.方法重载和方法重写的区别

方法重载(Overload) 和方法重写(Override)的去区别?
  	
  	方法重载:
  		方法名相同,参数列表不同,与返回值无关
 					参数个数
  					参数类型

 	方法重写:
  			子类继承父类的时候,子类出现了和父类一模一样的方法...(方法覆盖,方法复写...)
### 关于VIVO手机解锁Bootloader (BL) 的方法 #### 工具准备 为了成功解锁VIVO手机的Bootloader,用户需要下载并安装特定的工具包。此工具包名为 `vivo_fastboot_for_windows`[^1],它是一个专门为VIVO设备设计的Fastboot工具集合,适用于Windows操作系统。 #### 操作流程 完成工具包的准备工作之后,按照以下方式执行具体的操作: 1. **进入Bootloader模式** 用户可以通过两种途径进入Bootloader模式:一种是在文件夹中启动命令行工具(CMD),随后输入指令 `adb reboot bootloader`;另一种则是关闭手机电源后,同时按住开机键音量减键来手动触发Bootloader模式[^2]。 2. **运行解锁命令** 成功切换至Bootloader界面后,在命令提示符或者PowerShell窗口里输入指定的解锁指令 `fastboot bbk unlock_vivo` 来实现Bootloader的解锁功能。 #### 风险提醒 在进行上述操作之前,请务必做好充分的数据备份工作,因为一旦开始解锁过程,有可能造成原厂保修条款失效的情况发生。另外值得注意的是,某些特殊机型可能还需要前往官方售后服务网点办理降级服务才能满足解锁条件,比如VIVOFOLAD以及VIVOT1等型号都需要通过售后渠道来进行必要的固件版本调整[^4]。 对于部分品牌而言,例如一加系列,其解锁机制相对宽松一些,仅无需担心影响保修权益,而且还能随时重新锁定Bootloader恢复出厂设置状态[^3]。然而即便如此,仍然存在诸如无法继续享受在线增量更新(OAT),转而仅能接受完整包形式推送等问题,并且像微信指纹支付这样的便捷特性也会暂时丧失直至再次闭合BL为止。 ```bash # 示例代码展示如何使用fastboot命令解锁BL fastboot devices # 查看连接设备 fastboot oem unlock # 发送解锁请求给目标设备 ``` #### 总结说明 综上所述,针对同类型的VIVO智能手机产品线,它们各自有着专属的一套解决方案可供参考实施。无论是借助第三方开发资源还是依赖厂家授权手段达成最终目的,都离开严谨细致的态度对待整个环节每一步骤细节处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值