Java中如何实现类似C++结构体的二级排序
1:实现Comparable接口
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List; class User implements Comparable<User>{
private Integer id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int compareTo(User o) {
if (this.id == o.id) return this.name.compareTo(o.name); //id相同按name排序
else return this.id.compareTo(o.id); //按ID从小到大排序
}
} public class Main { /**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub String s1 = "abx";
String s2 = "小1";
System.out.println(s1.compareTo(s2)); List<User> users = new ArrayList<User>(); User u6 = new User();
u6.setId(6); u6.setName("Jack"); User u = new User();
u.setId(6); u.setName("abx"); User u1 = new User();
u1.setId(1); u1.setName("小1"); User u4 = new User();
u4.setId(4); u4.setName("小4"); User u2 = new User();
u2.setId(2); u2.setName("小2"); User u7 = new User();
u7.setId(6); u7.setName("abc"); users.add(u2);
users.add(u6);
users.add(u4);
users.add(u1);
users.add(u);
users.add(u7);
Collections.sort(users); for (User ui : users) {
System.out.println(ui.getId() + " " + ui.getName());
}
} }
2:集合外定义Comparator
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List; class User{
private int id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
} public class Main { /**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub String s1 = "abx";
String s2 = "小1";
System.out.println(s1.compareTo(s2)); List<User> users = new ArrayList<User>(); User u6 = new User();
u6.setId(6); u6.setName("Jack"); User u = new User();
u.setId(6); u.setName("abx"); User u1 = new User();
u1.setId(1); u1.setName("小1"); User u4 = new User();
u4.setId(4); u4.setName("小4"); User u2 = new User();
u2.setId(2); u2.setName("小2"); User u7 = new User();
u7.setId(6); u7.setName("abc"); users.add(u2);
users.add(u6);
users.add(u4);
users.add(u1);
users.add(u);
users.add(u7); Collections.sort(users, new Comparator<User>() {
@Override
public int compare(User o1, User o2) {
if (o1.getId() == o2.getId()) return o1.getName().compareTo(o2.getName());
return o1.getId() > o2.getId() ? 1 : -1;
} }); for (User ui : users) {
System.out.println(ui.getId() + " " + ui.getName());
}
} }
Java中如何实现类似C++结构体的二级排序的更多相关文章
- sort+结构体实现二级排序
之前介绍的sort函数由于其效率较高,使用较为简单让我用起来那叫一个爽,今天再写一篇使用sort+结构体实现二级排序的方法. 还是先想个问题吧,比如我想输入5个同学的名字和身高,然后得到他们身高的降序 ...
- 内核中用于数据接收的结构体struct msghdr(转)
内核中用于数据接收的结构体struct msghdr(转) 我们从一个实际的数据包发送的例子入手,来看看其发送的具体流程,以及过程中涉及到的相关数据结构.在我们的虚拟机上发送icmp回显请求包,pin ...
- YTU 2878: 结构体--学生信息排序
2878: 结构体--学生信息排序 时间限制: 1 Sec 内存限制: 128 MB 提交: 297 解决: 148 题目描述 定义存放一个学生信息的结构体类型,学生信息包括:姓名,学号,性别,院 ...
- Problem T: 结构体--学生信息排序
Problem T: 结构体--学生信息排序 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 2219 Solved: 1305[Submit][Sta ...
- Dalvik虚拟机java方法执行流程和Method结构体分析
Method结构体是啥? 在Dalvik虚拟机内部,每个Java方法都有一个对应的Method结构体,虚拟机根据此结构体获取方法的所有信息. Method结构体是怎样定义的? 此结构体在不同的andr ...
- ios开发中的C语言学习—— 结构体简介
在开发过程中,经常会需要处理一组不同类型的数据,比如学生的个人信息,由姓名.年龄.性别.身高等组成,因为这些数据是由不同数据类型组成的,因此不能用数组表示,对于不同数据类型的一组数据,可以采用结构体来 ...
- Linux字符设备中的两个重要结构体(file、inode)
对于Linux系统中,一般字符设备和驱动之间的函数调用关系如下图所示 上图描述了用户空间应用程序通过系统调用来调用程序的过程.一般而言在驱动程序的设计中,会关系 struct file 和 struc ...
- 大话Java中的哈希(hash)结构(一)
o( ̄▽ ̄)d 小伙伴们在上网或者搞程序设计的时候,总是会听到关于“哈希(hash)”的一些东西.比如哈希算法.哈希表等等的名词,那么什么是hash呢? 一.相关概念 1.hash算法:一类特殊的算法 ...
- c++中包含string成员的结构体拷贝导致的double free问题
最近调试代码遇到一个的问题,提示double free,但是找了好久也没有找到释放两次的地方,后来调试发现,是由于使用了一个包含string成员的结构体,这个结构体使用memcpy拷贝导致的问题: 代 ...
随机推荐
- 学习Spark2.0中的Structured Streaming(一)
转载自:http://lxw1234.com/archives/2016/10/772.htm Spark2.0新增了Structured Streaming,它是基于SparkSQL构建的可扩展和容 ...
- df值自由度学习[转载]
转自:https://www.applysquare.com/topic-cn/78TAnIzZ6/ https://zhidao.baidu.com/question/175605082855699 ...
- [LeetCode] questions conclustion_Path in Tree
Path in Tree: [LeetCode] 112. Path Sum_Easy tag: DFS input: root, target, return True if exi ...
- 在ASP.NET Web Application中通过SOAP协议调用Bing搜索服务
本文介绍了如何在ASP.NET Web Application中将Bing搜索作为Web Service来使用,并通过HTTP的SOAP协议在ASP.NET Web Application中调用Bin ...
- SQL Expression Language Tutorial 学习笔记一
http://docs.sqlalchemy.org/en/latest/core/tutorial.html Google 翻译了一下 SQLAlchemy Expression Language, ...
- 使用jmeter进行websocket协议压测
第一步:添加websocket sampler组件 可以使用plugins manager进行添加,首先下载plugins manager组件: 下载路径: https://jmeter-plugi ...
- input text文本框内部最后面放一个按钮
.ContSpan { border: 1px solid #; display: inline-block; } .ContSpan span { cursor: pointer; backgrou ...
- linux 启动引导流程
课程大纲: Linux引导流程 Linux运行级别 Linux启动服务管理 GRUB配置与应用 启动故障分析与解决 系统引导流程 1.固件firmware(CMOS(固化在硬件上的程序与硬件统称)/B ...
- Summary: Stack Overflow Error
What is a stack overflow error? Parameters and local variables are allocated on the stack (with refe ...
- python+Django框架运用(一)
Django 介绍: django是一个采用Python语言开发的开源框架,2005年发布.早期是做新闻以及内容管理的网站的,提供了非常强大的后管理系统. django官网:https://www.d ...