Java中对象数组的使用

Java中对象数组的使用给你一组学生的数据,比如姓名,性别,学号,成绩,然后根据成绩排序,这时你就得用对象数组啦

大家好,又见面了,我是你们的朋友全栈君。

一、Java数组的使用

对象数组其实和Java的数组类似的,所以要很清楚Java的数组是如何使用的,如果有不懂的可以点下面这个链接Java数组的使用

二、Java的对象数组

2.1 问题提出

为什么会有对象数组呢?假定有这种情况,我们需要录入一个班级同学的姓名,学号,和成绩,然后对成绩进行排序,以降序或者升序进行排列,这个时候就会有人跳出来说,我用一个字符串数组存储姓名,然后再用一个二维数组存放学号和成绩,然后根据程序的高低进行排序。

2.2 问题解析

NONONO!今天我们来教大家如何使用对象数组来解决这个问题,对象数组,我们前面学过Java(OOP)编程—(Java OOP编程),想必大家也对面向对象这个词也会稍微有了一些了解,对象数组就是可以存放多种不同的数据类型,然后我们通过对象来调用我们所存放的数据。

接下来我就来告诉大家如何使用对象数组,完成这个成绩排序的问题

2.3 问题拆分

我们可以把问题简化一下,输入五个学生的成绩,然后进行排序打印输出

  1. 先创建一个学生类
  2. 给学生类添加学生的信息—姓名,学号,成绩,然后分别生成有参和无参的构造方法
  3. 再创建一个学生测试类
  4. 创建对象数组,给对象数组申请 5 个空间
  5. 循环录入信息
  6. 根据学生成绩进行排序,然后打印输出
2.4 代码实现

创建一个学生类的属性,包括学生的姓名,学号,成绩
为了方便,我把两个文件放进了同一个包中使用

package A
/** * @author gorit * @date 2019年4月10日 * 对象数组学生类的创建 * */
public class Student { 
   
	private String name;//学生的姓名
	private int num;//学生的学号信息
	private int grades;//学生的成绩
	
	//有参的构造方法
	public Student(String name, int num, int grades) { 
   
		super();
		this.name = name;
		this.num = num;
		this.grades = grades;
	}

	//无参的构造方法
	public String getName() { 
   
		return name;
	}

	public void setName(String name) { 
   
		this.name = name;
	}

	public int getNum() { 
   
		return num;
	}

	public void setNum(int num) { 
   
		this.num = num;
	}

	public int getGrades() { 
   
		return grades;
	}

	public void setGrades(int grades) { 
   
		this.grades = grades;
	}

	public Student(){ 
   }

}

然后就是学生类的测试类

package A
/** * @author gorit * @date 2019年4月10日 * 对象数组的实例讲解 * */
import java.util.Scanner;

public class StudentTest { 
   
	public static void main(String[] args) { 
   
		System.out.println("请录入学生姓名,学号、成绩:");
		Scanner in=new Scanner(System.in);
// int[] a=new int[3];对照数组的使用
// 1、创建对象数组,Student类有三个属性,所以传入数据需要传三个数据
		Student[] s=new Student[5];//对象数组的创建是一样的
		for (int i = 0; i < s.length; i++) { 
   
			//还可以一个个输入s[i].getName,s[i].getNum,s[i].getGrade,一个个输入,用下面的方法更加快捷
			s[i]=new Student(in.next(),in.nextInt(),in.nextInt());
		}
		
		Student s1=null;//创建一个为空的对象进行数据交换
		//根据学生的成绩进行排序,这里运用冒泡排序
		for(int i=0;i<s.length;i++) { 
   
			for (int j =0; j < s.length; j++) { 
   
				if(j!=4)//这里必须加上这个条件,不然数字会报出越界的问题
				if(s[j].getGrades()<s[j+1].getGrades()) { 
   
					s1=s[j+1];
					s[j+1]=s[j];
					s[j]=s1;
				}
			}
		}
		
		System.out.println("学生的成绩排名如下\n姓名\t学号\t成绩");
		for (int i = 0; i < s.length; i++) { 
   
			System.out.println(s[i].getName()+"\t"+s[i].getNum()+"\t"+s[i].getGrades());
		}
		
	}
}

程序运行结果
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157866.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Windows Vista Ultimate OEM 21in1 简体中文版(终结版)

    Windows Vista Ultimate OEM 21in1 简体中文版(终结版)终结版总结:  包含19种OEM版本:,分别是Lenovo(联想),IBM(IBM),HP(惠普),Compaq(康柏),DELL(戴尔),ASUS(华硕),Acer(宏碁),BenQ(明基),Fujitsu(富士通),SAMSUNG(三星),SONY(索尼),TOSHIBA(东芝),NEC(NEC),LG(LG),FOUNDER(方正),TCL(梯西爱尔),HASEE(神舟电脑),HE…

    2022年8月31日
    2
  • IE8下textarea的onpropertychange问题Stack overflow at line.「建议收藏」

    IE8下textarea的onpropertychange问题Stack overflow at line.「建议收藏」代码如下:      Document            body{background:#fff;}      textarea{width:300px;min-height:60px;overflow:hidden;resize:none;}            $(function(){

    2022年7月15日
    17
  • c语言将时速转换成配速,配速和时速换算(配速时速换算)

    c语言将时速转换成配速,配速和时速换算(配速时速换算)时间除以路程,一般时间单位用分,路程单位用千米。比如20分钟跑了3千米,那配速就是20/3=6.66,也就是6分40秒每公里,一般说成640的配速。配速是针对长跑来说的,对短跑和中跑是不采用这个概念的。马拉松运动讲究匀速,在匀速的状态下才能更好地发挥自己的实力。很多跑步爱好者很注意控制速度。他们根.时速的意思是当时跑步的速度,配速是平均每公里耗时几分钟消耗是指跑步消耗的热量相当于每小时跑多少千…

    2022年6月28日
    170
  • 主机游戏神作和排行榜

    主机游戏神作和排行榜文章目录主机游戏任天堂、索尼、微软三大家任天堂索尼微软其他电视游戏主机(家用机)红白机时代PS时代次世代主机掌机其他游戏PC游戏平台Steam其他评分和榜单端游、页游和手游评分和榜单VR设备ValveIndexHTCViveOculusRiftSOculusQuest三星MR+权威游戏评分媒体TGAIGNGameSpot其他GameRankingsFami通MetacriticEGA游戏…

    2022年7月11日
    83
  • SATA接口定义

    SATA接口定义转自:https://blog.csdn.net/u013000139/article/details/50371568SATA数据接口(7针)电源接口(15针)定义详解SATA是SerialATA(SerialAdvancedTechnologyAttachment)亦称串行ATA,是由Intel、IBM、Dell、APT、Maxtor和Seagate公司共同提出的硬盘接口规范。…

    2022年5月1日
    32
  • 数据挖掘——关联规则挖掘

    数据挖掘——关联规则挖掘《数据挖掘》国防科技大学《数据挖掘》青岛大学数据挖掘之关联规则挖掘关联规则挖掘(AssociationRuleMining)最早是由Agrawal等人提出。最初的动机是解决购物篮分析(BasketAnalysis)问题,目的是发现交易数据库(TransactionDatabase)中不同商品之间的联系规则。定义关联规则是描述在一个交易中物品之间同时出现的规律的知识模式,更确切的说,关联规则是通过量化的数字描述物品X的出现对物品Y的出现有多大的影响。关联分析associationana

    2022年7月17日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号