我是靠谱客的博主 壮观美女,最近开发中收集的这篇文章主要介绍Java Day27,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

增删改查项目总结

目录
增删改查排序 1
保存学生的数组allStus是类内成员变量,下边的几个方法可以直接拿来用,所以无需作为参数传入 1
测试类中调用manager类的有参和无参构造方法*** 1
错误1 构造方法中 【Student 】allStus = new Student[initCapacity] 3
增 3
类内成员变量计数器size 3
add实现 3
grow注意判断扩容之后的容量是否满足最小容量要求(size+1) 3
删(删除之后注意size -= 1,保证size一直是有效元素个数) 4
错误2 正 if (id == allStus[i].getId() 错【if (id == i)】 要删除的是指定id的学生,而不是数组中下标为i的元素 4
查 4
改 通过类内其他成员方法获取对应ID的学生类对象Student stu = get(id){开发过程中注意使用其他代码简化自己}; 5

增删改查排序

保存学生的数组allStus是类内成员变量,下边的几个方法可以直接拿来用,所以无需作为参数传入
public class StudentManager {
private Student[] allStus = null;
增方法:
① public boolean add(Student student) {}
add中的student参数是在其他类中传入的,类内不能定义,所以需要作为参数传入。
删方法:
② public boolean remove(int id) {}
同理,指定要删除的id需要后期传入,类内不能定义,所以需要作为参数传入。
}
初学方法时的几种找下标方法 需要数组传入 是因为数组和方法是在不同的大括号内,需要传入,数组是局部变量

测试类中调用manager类的有参和无参构造方法***
public class StudentTest {
@Test
public void testAdd() {
StudentManager stm = new StudentManager(5);
new StudentManager(5);此处括号内有5,选择有参数构造方法,数组容量即为5;若没有数字(即用户没有指定数组容量),选择无参构造方法,数组容量即为默认的DEFAULT_CAPACITY。
stm.add(new Student(1, “骚磊”, 16, ‘男’, 100));
stm.add(new Student(2, “骚磊”, 16, ‘男’, 100));
匿名对象new Student调用Student类有参构造方法,作为方法参数传入add方法
StudentManager类内无参数构造方法
public StudentManager() {
allStus = new Student[DEFAULT_CAPACITY];
}
StudentManager类内有参数构造方法(参数是用户输入的数组容量)
public StudentManager(int initCapacity) {
if (用户传入参数合法性判断) {}
经判断参数合理,然后作为数组容量使用
allStus = new Student[initCapacity];
错误1 构造方法中 【Student 】allStus = new Student[initCapacity]

类内成员变量计数器size
把一个一个的学生对象放入allStus数组中,需要一个计数器 size,而且size必须是类内成员变量,保证每次调用add方法添加一个学生对象之后size数值都随之加一(保证每一个StudentManager对象中存储的内容都是独立,是根据当前数组中存储数据的容量来确定)

stm.add(new Student(1, “骚磊”, 16, ‘男’, 100));
stm.add(new Student(2, “骚磊”, 18, ‘女’, 99));
size就是数组内有效元素
add实现:

public boolean add(Student student) {
if (size == allStus.length) {
grow(size + 1);}
本来的数组容量不够用了,调用grow扩容
allStus[size] = student;
size += 1;
return true;
}
private void grow(int minCapacity) {}
int newCapacity = oldCapacity + oldCapacity / 2;

grow注意判断扩容之后的容量是否满足最小容量要求(size+1),因为使用的是1/2扩容,可能会出现eg:新容量=1+1/2=1.5,会不够用,如果不满足用最小容量替换
最后数据拷贝 然后使用allStus保存新数组首地址
allStus = temp;
删(删除之后注意size -= 1,保证size一直是有效元素个数)
① 是否找到
② 删除它 再把它之后的每个元素前移一位
③ 最后一个有效元素位置赋值为null
④ 有效元素个数减一 size -= 1;

public boolean remove(int id){
int index = -1;
for (int i = 0; i < size; i++) {
if (id == allStus[i].getId()) {
if判断找到了指定id

错误2 正 if (id == allStus[i].getId() 错【if (id == i)】 要删除的是指定id的学生,而不是数组中下标为i的元素
index = i;


找到之后返回一个学生类对象public Student get(int id){}
改 通过类内其他成员方法获取对应ID的学生类对象Student stu = get(id){开发过程中注意使用其他代码简化自己};
public boolean modify(int id) {
Student stu =get(id);}
通过get获取到一个学生对象,然后赋值给student引用
通过scanner修改以后 再用Student类对象 调用set方法赋值

最后

以上就是壮观美女为你收集整理的Java Day27的全部内容,希望文章能够帮你解决Java Day27所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(73)

评论列表共有 0 条评论

立即
投稿
返回
顶部