前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >List的使用(Java)

List的使用(Java)

作者头像
GeekLiHua
发布于 2025-01-21 04:19:20
发布于 2025-01-21 04:19:20
11700
代码可运行
举报
文章被收录于专栏:JavaJava
运行总次数:0
代码可运行

顺序表(List)系列

ArrayList

简介
声明方式

从这里开始就是Java的STL与C++STL最大的区别了 声明方式有很大的不同

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import java.util.*;

public class Main{	
	public static void main(String[] args) {
		List<Integer> list = new ArrayList<Integer>(); // 正确语法
		List<Integer> list3 = new LinkedList<Integer>(); // 正确语法
	
		List<Integer> list2 = new List<Integer>();  // 错误语法 
	}
}

List不能通过自己来实现 需要通过他的子类来实现

常用方法

add(第一种)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(2);
		list.add(3);		
		System.out.println(list);
		/*[1, 2, 3]*/

add(第二种)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(2);
		list.add(3);
		list.add(3, 1);
		System.out.println(list);
		/*
		 * [1, 2, 3, 1]
		 */		

remove remove(int position) 按照索引删除值

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(2);
		list.add(3);
		list.remove(1);
		System.out.println(list);
		/*
		 * [1, 3]
		 */		

remove remove(String item) 删除第一个出现的这个匹配的字符串

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<String> list = new ArrayList<String>();
		list.add("123");
		list.add("1234");
		list.add("12345");
		list.add("123456");
		System.out.println(list);
		/*
		 * [123, 1234, 12345, 123456]
		 */		
		list.remove("12345");
		System.out.println(list);
		/*
		 * [123, 1234, 123456]
		 */

removeAll void removeAll

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(2);
		list.add(3);		
		System.out.println(list);
		/*[1, 2, 3]*/
		list.removeAll(list);
		System.out.println(list);
		/*		 
		   []
		 */

get get(int index)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<String> list = new ArrayList<String>();
		list.add("123");
		list.add("1234");
		list.add("12345");
		list.add("123456");
		System.out.println(list.get(3));/*123456*/	

set set(int index E element)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
List<String> list = new ArrayList<String>();
		list.add("123");
		list.add("1234");
		list.add("12345");
		list.set(2, "497");
		System.out.println(list);
		/*
		 * [123, 1234, 497]
		 */
遍历方式
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args) {
		ArrayList<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(3);
		list.add(2);
		list.add(4);
		list.add(5);
		list.add(0);
		
	    // 方法一
		for(int i = 0; i < list.size(); ++ i)
		{
			System.out.print(list.get(i) + " ");
		}
		/*1 3 2 4 5 0 */
		
		System.out.println();
		
		// 方法二
		Iterator it = list.iterator();
		while(it.hasNext())
		{
			System.out.print(it.next() + " ");
		}
		/*1 3 2 4 5 0 */
		
		System.out.println();		
		// 方法三
		for(Integer i : list)
		{
			System.out.print(i + " ");
		}
		/*1 3 2 4 5 0 */
	}
排序
使用Comparator自定义排序
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args) {
		ArrayList<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(3);
		list.add(2);
		list.add(4);
		list.add(5);
		list.add(0);
		// 顺序排列
		list.sort(new Comparator<Integer>() {
			@Override
			public int compare(Integer o1, Integer o2) {
				// TODO Auto-generated method stub
				int num = 0;
				if (o1 > o2) num = 1;
				else if (o1 == o2) num = 0;
				else num = -1;
				return num;
				
			}			
		});
		System.out.println(list);
		/*[0, 1, 2, 3, 4, 5]*/
		
		// 逆序排列
		list.sort(new Comparator<Integer>() {
			@Override
			public int compare(Integer o1, Integer o2) {
				// TODO Auto-generated method stub
				int num = 0;
				if (o1 > o2) num = -1;
				else if (o1 == o2) num = 0;
				else num = 1;
				return num;
				
			}			
		});
		System.out.println(list);
		/*[5, 4, 3, 2, 1, 0]*/
	}
利用Collections.sort()排序
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public static void main(String[] args) {
		ArrayList<Integer> list = new ArrayList<Integer>();
		list.add(1);
		list.add(3);
		list.add(2);
		list.add(4);
		list.add(5);
		list.add(0);
		
		// Collections.sort()默认顺序
		Collections.sort(list);
		System.out.println(list);
		/*[0, 1, 2, 3, 4, 5]*/
		
		// 自定义排序
		Collections.sort(list, new Comparator<Integer>() {

			@Override
			public int compare(Integer o1, Integer o2) {
				// TODO Auto-generated method stub
				return o2.compareTo(o1);
			}			
		});
		
		System.out.println(list);
		/*[5, 4, 3, 2, 1, 0]*/
	}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
深入浅出 React Hooks
Hooks 顾名思义,字面意义上来说就是 React 钩子的概念。通过一个 case 我们对 React Hooks 先有一个第一印象。
桃翁
2019/06/12
2.6K0
手写ReactHook核心原理,再也不怕面试官问我ReactHook原理
调用useState会返回一个state变量,以及更新state变量的方法。useState的参数是state变量的初始值,初始值仅在初次渲染时有效。
JowayYoung
2021/02/03
4.5K1
手写ReactHook核心原理,再也不怕面试官问我ReactHook原理
快速上手 React Hook
Hook 是 React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。本篇文章将介绍React Hook相关知识。
用户8921923
2022/10/24
5.2K0
React Hook
在传统的 class 中,会使用 componentDidMount 和 componentDidUpdate 获取数据。同时 componentDidMount 中也会处理一些其他的事务,例如事件监听,定时器等等。而后还需要在 componentWillUnmount 中取消。万一忘记其中某一个部分或者处理的时间过多,很可能导致一些可怕的bug。
踏浪
2020/01/17
2K0
宝啊~来聊聊 9 种 React Hook
文章会为你讲述 React 9种 Hook 的日常用法以及进阶操作,从浅入深彻底掌握 React Hook!
19组清风
2022/02/28
1.1K0
宝啊~来聊聊 9 种 React Hook
彻底搞懂React-hook链表构建原理
React 在初次渲染或者更新过程中,都会在 render 阶段创建新的或者复用旧的 fiber 节点。每一个函数组件,都有对应的 fiber 节点。
夏天的味道123
2022/10/18
6370
React Hooks 分享
        hooks: 钩子, React Hooks 的意思是,组件尽量写成纯函数,如果需要外部功能和副作用,就用钩子把外部代码"钩"进来 。
子夜星辰
2022/11/15
2.4K0
React Hooks 分享
彻底搞懂React-hook链表构建原理_2023-02-27
React 在初次渲染或者更新过程中,都会在 render 阶段创建新的或者复用旧的 fiber 节点。每一个函数组件,都有对应的 fiber 节点。
用户10376779
2023/02/27
8750
再聊react hook
React Hook是React函数式组件,它不仅仅有函数组件的特性,还带有React框架的特性。所以,官网文档多次强调:
娜姐
2020/12/11
1K0
React Hook丨用好这9个钩子,所向披靡
[raect] React Hook 指南 什么是 Hook ? Hook 是 React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。 Hook 本质上就是一个函数,它简洁了组件,有自己的状态管理,生命周期管理,状态共享。 useState useEffect useContext useReducer Hook 出现解决了什么 ? 组件之间状态复用, 例如:使用useContext 可以很好的解决状态复用问题,或者自定义Hook 来定制
程序员海军
2022/02/15
3.3K0
React Hook丨用好这9个钩子,所向披靡
浅谈 Hooks
如果你很熟悉 vue 与 react ,兴许你也觉得 vue3.0 抄袭了react,这项react 在不久前发布的新技术,在 vue3.0 中被重新搬上了舞台。也使它重新活跃在了人们的视野中,我技术不深,与大家分享我的见解和猜测。
我不是费圆
2020/10/13
2K0
React-Hook最佳实践
Hooks 是 React 16.8 新增的特性,它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性,无需转化成类组件
xiaofeng123aa
2022/10/17
4.1K0
Note·React Hook
React Hook 是 React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。
数媒派
2022/12/01
2.2K0
useTypescript-React Hooks和TypeScript完全指南
React v16.8 引入了 Hooks,它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。这些功能可以在应用程序中的各个组件之间使用,从而易于共享逻辑。Hook 令人兴奋并迅速被采用,React 团队甚至想象它们最终将替换类组件。
前端森林
2020/04/23
9.2K0
useTypescript-React Hooks和TypeScript完全指南
React实战精讲(React_TS/API)
今天,我们继续「前端面试」的知识点。我们来谈谈关于「React实战」的相关知识点和具体的算法。
前端柒八九
2022/12/19
10.6K0
React实战精讲(React_TS/API)
React Hooks教程之基础篇
Hook 是 React 16.8 的新增特性。它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。
乐圣
2022/11/19
3.1K0
超详细preact hook源码逐行解析
preact hook 作为一个单独的包preact/hook引入的,它的总代码包含注释区区 300 行。
ACK
2020/01/14
2.7K0
React-hooks面试考察知识点汇总
React 没有提供将可复用性行为“附加”到组件的途径(例如,把组件连接到 store)。有一些解决此类问题的方案,比如 render props 和 高阶组件。但是这类方案需要重新组织你的组件结构,这可能会很麻烦,使你的代码难以理解。
beifeng1996
2022/10/06
1.4K0
【react】203-十个案例学会 React Hooks
原文地址:https://github.com/happylindz/blog/issues/19
pingan8787
2019/07/23
3.2K0
前端一面必会react面试题(持续更新中)
React Router 提供一个routerWillLeave生命周期钩子,这使得 React组件可以拦截正在发生的跳转,或在离开route前提示用户。routerWillLeave返回值有以下两种:
beifeng1996
2022/12/15
1.8K0
相关推荐
深入浅出 React Hooks
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档