首页 > 其他分享 >接口

接口

时间:2023-06-29 15:36:20浏览次数:40  
标签:index students 接口 id Student public

信息管理系统优化(更换容器)

  • 改进点

    我们需要将容器修改成集合,而在我们的分类思想中Dao类才是需要和数据进行交互的,所以其实我们只需要修改Dao类就可以了。在新的Dao中所提供的类的名称和之前一致即可(如果不一致则影响Service类的调用)
  • 我们的修改遵循开闭原则,不更改原来的代码类

这次我们的根据开闭原则新创建了一个OtherStudentDao类,注意:我们不要修改OtherStudentDao类中任何方法的定义,如果我们修改了OtherStudentDao中方法的定义,可能会导致StudentServiece和Control类中相应的方法也需要改变(因为Serviece类会调用Dao中相应的方法)

信息管理系统----抽取公共Dao

  • 存在的问题

  • 1.StudentDa和OtherStudentDao类有相同的部分,可以提取成一个父类
  • 2.因为父类中的方法无法具体描述所以写成一个抽象类
  • 父类
package com.itheima.edu.info.manager.dao;

import com.itheima.edu.info.manager.domain.Student;

import java.util.ArrayList;

//dao包库管,对数据进行操作
public abstract class BaseStudentDao {
    public abstract boolean addStudent(Student student) ;

    public abstract Student[] findAllStudent() ;

    public abstract void deleteStudentById(String id) ;
    //通过id找到他在数组中的索引
    public abstract int getIndex(String id);

    public abstract void updateStudent(String id, Student student);
}

  • 子类
package com.itheima.edu.info.manager.dao;

import com.itheima.edu.info.manager.domain.Student;

//dao包库管,对数据进行操作
public class StudentDao    extends BaseStudentDao {
   //创建Student学生数组长度为5
   private static Student[] students = new Student[5];
   //静态代码块初始化学生数据
    static {
        Student s1 = new Student("001", "张三", 18, "1990-01-01");
        Student s2 = new Student("002", "李四", 23, "1937-03-01");
        students[0] = s1;
        students[1] = s2;
   }
   @Override

    public boolean addStudent(Student student) {


        //2.将接收到的学生对象添加到数组中
        //2.1定义遍历index=-1
        int index = -1;
        //2.2遍历数组中的每一个元素,判断是否为null
        for (int i = 0; i < students.length; i++) {
            if (students[i] == null) {
                index = i;
                break;
            }
        }
        //3.返回是否添加成功
      if (index == -1) {
           //装满了
            return false;
        } else {
          //没有装满,正常添加,返回true
          students[index] = student;
            return true;
        }
    }
@Override
    public Student[] findAllStudent() {
        //返回我们创建的对象数组
        return students;
    }
@Override
    public void deleteStudentById(String id) {
        //1.找到该id在数组中对应的索引
        int index = getIndex(id);
        //2.将该索引的对象使用null替代
        students[index] = null;
    }
    //通过id找到他在数组中的索引
    @Override
    public int getIndex(String id){
        int index=-1;//记录id对应索引的的位置
        for (int i = 0; i < students.length; i++) {
            if(students[i]!=null&&id.equals(students[i].getId())){
                index=i;
                break;
            }
        }
        return index;
    }
@Override
    public void updateStudent(String id, Student student) {
        //1.查找id在容器中的索引
        int index = getIndex(id);
        //2.将该索引的位置,使用新的学生对象替换
        students[index] = student;
    }
}

package com.itheima.edu.info.manager.dao;

import com.itheima.edu.info.manager.domain.Student;

import java.util.ArrayList;

//dao包库管,对数据进行操作
public class OtherStudentDao  extends BaseStudentDao  {
   //使用集合作为容器
  //private static Student[] students = new Student[5];
    private static ArrayList<Student> students = new ArrayList<>();
   //静态代码块初始化学生数据
    static {
        Student s1 = new Student("001", "张三", 18, "1990-01-01");
        Student s2 = new Student("002", "李四", 23, "1937-03-01");
        students.add(s1);
        students.add(s2);
   }

   @Override
    public boolean addStudent(Student student) {
       //因为集合装不满,所以不需要进行判断,直接添加即可
        students.add(student);
        return true;



    }
@Override
    public Student[] findAllStudent() {
        //1.我们可以选择返回数组或者即可
        //2.返回集合将会修改Service和Controller中的代码,我们选择返回数组
        //3.然后将集合中的元素全部装回数组中
        Student[] stu = new Student[students.size()];//数组的长度和集合长度保持一致
        stu =students.toArray(stu);//将集合变成数组返回
        return stu;

    }
@Override
    public void deleteStudentById(String id) {
        //1.找到该id在数组中对应的索引
        int index = getIndex(id);
        //2.将该索引的对象使用null替代
        students.remove(index);
    }
    //通过id找到他在数组中的索引
    @Override
    public int getIndex(String id){//(改为遍历集合即可)
        int index=-1;//记录id对应索引的的位置
        for (int i = 0; i < students.size(); i++) {
            if(students.get(i)!=null&&id.equals(students.get(i).getId())){
                index=i;
                break;
            }
        }
        return index;
    }
@Override
    public void updateStudent(String id, Student student) {
        //1.查找id在容器中的索引
        int index = getIndex(id);
        //2.将该索引的位置,使用新的学生对象替换
        students.set(index, student);
    }
}

在这次优化中,我们是先有子类,然后才抽取成父类,这样好像看不出什么好处。但是我们可以先定义抽象父类(制定模板),然后子类继承模板,然后只需要完成模板的内容即可,这样我们编写代码更简便

接口的介绍

  • 存在问题
  • 接口定义

接口的定义和特点


接口实现类的命名规则:

  • 如接口Inter
  • 实现类 InterImpl
    前半部分往往是接口的名字,后半部分是Implements的缩写(Impl)
  • 重点
    1.和继承相比,接口可以进行多继承,拓展性更强
    2.多实现接口不会和多继承一样存在逻辑冲突吗?
    不会存在逻辑冲突。多继承中当多个父类存在相同的方法时,子类在调用的时候会存在不知道调用那个的问题
    而如果多个接口中存在相同的抽象方法需要实现,因为接口中都是抽象方法,不存在具体逻辑,子类只用实现其中的一个即可

接口中成员的特点

  • 注意点:
    1.系统默认给接口中成员添加public static final(所以一定是常量)
    2.接口中没有构造方法,所以子类中的构造方法默认super()访问的是object中的构造方法
    3.接口中的方法自动添加 public abstract(默认为抽象方法)
  • 总结

JDK8版本中成员的特点---默认方法

  • 原有接口存在的问题

    安装原来的标准来说:我们需要在接口中添加方法,而且只能是抽象方法。此时我们的所以实现类必须抽象新添加的方法。如果不重写,我们所有的实现类都会报错

  • 解决方法

  • JDK8成员方法的特点

    1.接口中的默认方法可以被子类重写,但是 不需要添加default关键字

  • 2.默认方法的权限默认使用public(不写系统会自动添加)
    3.当实现类实现多个接口,而多个接口有相同定义的默认方法,此时调用默认方法,java会怎样应对?
    这样又回到了之前的逻辑问题,为了解决这样的逻辑冲突问题,java则执行:实现类必须要重写多个相同的默认方法的策略,然后调用的时候则是调用自己重写的方法(不知道调用哪一个,则调用自己实现的)

  • 注意事项

JDK8版本中接口成员的特点--静态方法

  • 注意点
    1.接口中定义的静态方法只能通过接口名进行调用(实现类对象无法调用)
    2.接口中静态方法权限默认为public,如果不写系统默认帮我们添加

3.接口中静态方法的调用不存在逻辑冲突问题(多个接口中定义相同的静态方法)
因为接口中的静态方法只能通过接口名进行调用,可以通过不同的接口名区分调用的方法

  • 注意事项

JDK9版本中接口成员的特点---private方法

  • 存在场景

  • 定义格式

    如果在接口中的方法是不需要外界进行访问就可以考虑定义为私有方法

  • 接口使用思路总结

类和接口的关系

  • 一个细节

当一个接口A继承了多个接口,而多个接口中有相同的默认方法。此时接口A不知道继承哪个接口。此时的接口A方案是在接口中重写这个方法,并使用自己重写的方法

信息管理系统---接口优化

  • 改进点

    我们重上面抽象类的优化中可以看出此时我们的抽象父类所有的方法都是抽象方法,此时正好符合接口的定义,故可以进一步优化

标签:index,students,接口,id,Student,public
From: https://www.cnblogs.com/swtaa/p/17511346.html

相关文章

  • django使用gunicorn框架,客户端请求耗时接口被中断问题
    项目使用的是django,使用了gunicorn作为动态web服务,使用的是supervisor作为进程管理工具。由于特殊原因,最近上线了一个非常耗时的http接口,一段时间后开始有用户陆续反馈他们的代码调用这个接口会返回502错误,经过一段时间的排查排除了网关的问题,确认是系统问题。经过......
  • C# HttpClient、API访问插件、接口访问
    关于使用插件访问接口.Net版本:NETFramework4.7.2 RestSharp版本:105.2.3.0Post访问 staticstringPostAction(){//公共apiconststringurl="https://api.uomg.com/api/rand.qinghua";//添加api访问......
  • Apifox:在线调试 OpenAI 接口,提供便捷的开发体验
    OpenAI 的API不仅可以通过编程语言(如Python、node.js)进行调用,还可以借助 Apifox 来在线调试。Apifox提供了直观且功能强大的方式来调试OpenAI接口,帮助开发者高效地发现和解决潜在问题。通过利用Apifox,开发者能够更快速地对项目进行迭代优化,确保OpenAI接口的稳定性和可......
  • php通过Curl给接口上传文件。
    在PHP中使用cURL上传文件至接口,你可以通过CURLOPT_POSTFIELDS选项来设置文件的内容。以下是一个示例:functionuploadFile($url,$filePath,$fieldName){$ch=curl_init($url);$postData=array($fieldName=>newCURLFile($filePath));c......
  • 注册功能接口
    [tov]注册功能#前端传入的数据 {手机号,验证码,密码}#后端要验证数据--->序列化类#遇到的错误 1注册使用哪个序列化了:get_serializer_class2配置文件中debug必须是True,因为咱们有万能验证码--->正常流程这个不需要3把code,弹出来,加入用户名,你可以随机生成用户......
  • pytest接口自动化测试框架搭建的全过程
    pytest是Python的一种单元测试框架,可用来组织用例执行,用例断言,下面这篇文章主要给大家介绍了关于pytest接口自动化测试框架搭建的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下一.背景Pytest目前已经成为Python系自动化测试必学必备的一个框架,网上也有很多......
  • 登录注册分析、多方式登录接口
    目录一、登录注册页面分析二、路由总路由分路由:user/urls.py三、验证手机号是否存在接口3.1不同方式验证手机号3.2固定写法:四、后端多方式登录接口user/views.pyuser/serializers.py一、登录注册页面分析#根据原型图分析出:要写的功能#用户名密码登录接口#注册功......
  • api接口接入淘宝/天猫平台采集添加到购物车数据调用演示案例
    ​淘宝添加到购物车API接口的作用是向淘宝购物车中添加指定的商品,实现用户将商品加入购物车的功能。通过该API接口,用户可以将商品加入购物车,方便后续进行结算和购买。使用淘宝添加到购物车API接口,可以帮助开发者和商家进行以下操作:购物车管理:允许用户将商品添加到购物车并进行......
  • 在EasyCVR中调用快照接口返回404是什么原因?如何解决?
    EasyCVR视频融合平台基于云边端一体化架构,能在复杂的网络环境中将前端设备进行统一集中接入,实现视频资源的汇聚管理、直播鉴权、转码处理、多端分发、智能告警、数据共享等能力与服务。此外,平台也提供了丰富的API接口供用户自由调用、集成与二次开发。有用户反馈,在EasyCVR中调用......
  • 前端打包部署后接口BASE_URL不对问题解决办法
    在前端打包部署时,为了免去不同环境打包的麻烦,项目用的流水线触发方式。在这里不细说,重点说说下面情况。当项目提交打包部署后,访问压测环境或者生产环境的地址来使用项目时,发现接口报错404。 在NETWORK里发现接口的BASEURL和当前环境需要调用的后端baseurl不同。主要问题在于......