集合类--arraylist学习笔记

(1)内存模型
图源自慕课网
动态存取性质:arraylist是从上至下从0开始的。第一个元素在0位,插入第二个,第一个元素向下一位到1号位,第二个元素在列顶0号位。当我指定插入在0号位,所有元素向下移一个。
但如果插入位置超过了目前含有的元素,比如说4,会报数组指针越界异常。也就是说不能超出它已有的内存长度。
示例代码:

public class ListTest {
	public List<Course> coursesToSelect;//接口list装很多对象的
	public ListTest() {
		this.coursesToSelect = new ArrayList<>();//用子类容器实例化
	}
	//添加课程
	public void testAdd() {
		Course c1 = new Course("1","数据结构");
		coursesToSelect.add(c1);//调用集合类添加方法
//		从序列中取出课程 打印出来说明存放进去了
//		System.out.println("打印一下好勒"+coursesToSelect.get(0));输出地址值
//		list中是从上到下由0开始,所以第一个索引是0
		System.out.println("添加了课程:"+((Course)coursesToSelect.get(0)).getIdandName());//强转程course类型的对象
		
		Course c2 = new Course("2","java从入门到放弃");
//		coursesToSelect.add(2, c2);//指针越界 因为序列就一个元素,不能插到索引2,位置3的地方
		coursesToSelect.add(1, c2);//c2插进去 
		int temp = coursesToSelect.indexOf(c2);//????到底是怎么动态存取。。
		System.out.println("c2的索引值"+temp);
		System.out.println("添加了课程:"+coursesToSelect.get(temp).getIdandName());
		/*
		 * 指定位置插入 并思考这个元素在内存模型中的位置(直接输出3个对象的地址码)
		 */
		Course c3 = new Course("3","python天下第一");
		coursesToSelect.add(0, c3);
		System.out.println("添加了课程:"+coursesToSelect.get(0).getIdandName());
		for(Course c:coursesToSelect) {
			System.out.println(c+"    "+c.getIdandName());
		}		
	}
	public static void main(String[] args) {
		ListTest lt = new ListTest();
		lt.testAdd();
	}
}


但这里有个困惑:按照老师讲的,c2应该在c1上方,为什么先输出c1呢。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
很好的问题!让我来解答。 首先,让我们来了解一下 `Comparable` 接口。这个接口是 Java 中的一个接口,它只有一个方法 `compareTo()`。这个方法的作用是定义类的自然排序顺序。 如果我们要对一个对象集合进行排序,只需要让这个类实现 `Comparable` 接口,并且重写 `compareTo()` 方法。这个方法返回一个整型值,表示该对象与另一个对象的大小关系。如果该对象小于另一个对象,则返回负整数;如果两个对象相等,则返回零;如果该对象大于另一个对象,则返回正整数。 下面是一个简单的例子,展示如何使用 `Comparable` 接口进行排序。 ```java public class Student implements Comparable<Student> { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } // 重写 compareTo 方法 @Override public int compareTo(Student o) { // 按照年龄从小到大排序 return this.age - o.getAge(); } } ``` 在这个例子中,我们定义了一个 `Student` 类,并且让它实现了 `Comparable` 接口。我们重写了 `compareTo()` 方法,按照年龄从小到大排序。 现在,我们可以使用 `Collections.sort()` 方法对 `Student` 对象进行排序了: ```java List<Student> students = new ArrayList<>(); students.add(new Student("Tom", 20)); students.add(new Student("Jerry", 18)); students.add(new Student("Alice", 22)); Collections.sort(students); for (Student student : students) { System.out.println(student.getName() + " " + student.getAge()); } ``` 输出结果为: ``` Jerry 18 Tom 20 Alice 22 ``` 可以看到,我们成功地按照年龄从小到大对 `Student` 对象进行了排序。 希望这个例子能够帮助你理解如何使用 `Comparable` 接口进行排序。如果你还有其他问题,请随时提出!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值