用Collection.sort对 ArrayList容器中对象的id 进行排序

本文详细介绍了如何使用Collection.sort方法对ArrayList容器内的对象依据其id属性进行排序,包括排序原理和具体实现步骤,帮助理解Java集合排序机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;


public class test {
	int id ;
	String name;
	public test(int id,String name)
	{
		this.id = id;
		this.name = name;
	}
	public static void main(String[] args) 
	{
		test test1 = new test(3,"yi");
		test test2 = new test(6,"er");
		test test3 = new test(9,"san");
	    List<test> list = new ArrayList<test>();
	    list.add(test1);
	    list.add(test2);
	    list.add(test3);
	   //lambda方法如下(升序)
	   // Collections.sort(list,(c1,c2)->c1.id-c2.id);
//匿名类方法如下(升序)
	    Collections.sort(list, new Comparator<test>()
	    {


			@Override
			public int compare(test o1, test o2) {
				// TODO Auto-generated method stub
				return o1.id-o2.id;
			}
	    	
	    }
	       
	    );
	    for(test each : list)
	    System.out.println(each.id);
	}
}
//一个很用心的java自学网站,有视频教学、详细答案,
//附带小项目练手,体验完整的开发流程,边做边学
链接 :http://how2j.cn?p=31723 点击打开链接


### 关于 `org.collection.ArrayList` 和 `java.util.ArrayList` 在讨论 `org.collection.ArrayList` 和 `java.util.ArrayList` 的差异之前,需要注意的是,标准的 Java API 并未定义名为 `org.collection.ArrayList` 的类。因此可以推测这是一个自定义包或者第三方库中的实现[^6]。 #### 1. **Java 标准库中的 `java.util.ArrayList`** `java.util.ArrayList` 是 Java 集合框架的一部分,是一个基于动态数组的数据结构,提供了灵活的大小调整功能,并允许通过索引快速随机访问元素。以下是其一些核心特性: - 它实现了 `List` 接口并继承了抽象类 `AbstractList`。 - 提供常数时间复杂度的随机访问操作(即 O(1) 时间复杂度)。 - 插入和删除操作的时间复杂度通常较高,因为可能涉及底层数组的复制或移动。 - 支持自动扩容机制,在容量不足时会创建更大的底层数组并将原数据迁移过去[^7]。 示例代码如下: ```java import java.util.ArrayList; public class Example { public static void main(String[] args) { ArrayList<String> list = new ArrayList<>(); list.add("Element"); System.out.println(list.get(0)); // 输出 "Element" } } ``` #### 2. **假设存在的 `org.collection.ArrayList`** 如果存在一个名为 `org.collection.ArrayList` 的类,则可能是某个特定项目或开发者为了满足某些需求而自行开发的一种替代方案。这种情况下,它的设计目标可能会有所不同,具体取决于其实现细节。以下是一些可能的区别方向: - **性能优化**:该版本可能针对某种特殊的场景进行了性能上的改进,比如减少内存占用、提高并发处理能力等。 - **功能性扩展**:相比标准版,它或许增加了额外的功能支持,例如更复杂的序列化逻辑或是定制化的迭代器行为。 - **线程安全性**:虽然传统的 `ArrayList` 不具备内置同步机制,但此变体也许引入了一些基本的锁控制或其他形式的安全保障措施[^8]。 由于缺乏具体的文档描述,以上仅为理论分析;实际应用中应查阅相关源码以获得确切信息。 --- ### 总结两者的主要区别 | 特性 | `java.util.ArrayList` | 假设的 `org.collection.ArrayList` | |---------------------|-----------------------------------------------|------------------------------------------| | 所属API | JDK自带的标准集合框架 | 可能来自外部库或个人项目 | | 主要特点 | 动态数组,高效随机存取 | 或有独特优势如增强型接口/更高效率 | | 默认线程安全状态 | 否 | 待定 | 请注意上述表格仅作示意之用,具体情况需依据真实环境下的定义为准。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值