Java List<>的用法及其方法

本文详细介绍了Java中List接口及其实现类ArrayList和LinkedList的使用方法,包括add、set、indexOf、lastIndexOf等常用方法的区别与应用,并提供了示例代码。

一、List的用法

List包括List接口以及List接口的所有实现类。因为List接口实现了Collection接口,所以List接口拥有Collection接口提供的所有常用方法,又因为List是列表类型,所以List接口还提供了一些适合于自身的常用方法。


二、 List接口定义的常用方法及功能
List接口提供的适合于自身的常用方法均与索引有关,这是因为List集合为列表类型,以线性方式存储对象,可以通过对象的索引操作对象。
List接口的常用实现类有ArrayList和LinkedList,在使用List集合时,通常情况下声明为List类型,实例化时根据实际情况的需要,实例化为ArrayList或LinkedList,例如:
List<String> l = new ArrayList<String>();// 利用ArrayList类实例化List集合
List<String> l2 = new LinkedList<String>();// 利用LinkedList类实例化List集合
1.add(int index, Object obj)方法和set(int index, Object obj)方法的区别
在使用List集合时需要注意区分add(int index, Object obj)方法和set(int index, Object obj)方法,前者是向指定索引位置添加对象,而后者是修改指定索引位置的对象,例如执行下面的代码:
public static void main(String[] args) {
	String a = "A", b = "B", c = "C", d = "D", e = "E";
	List<String> list = new LinkedList<String>();
	list.add(a);
	list.add(e);
	list.add(d);
	list.set(1, b);// 将索引位置为1的对象e修改为对象b
	list.add(2, c);// 将对象c添加到索引位置为2的位置
	Iterator<String> it = list.iterator();
	while (it.hasNext()) {
		System.out.println(it.next());
	}
}
在控制台将输出如下信息:
A
B
C
D


因为List集合可以通过索引位置访问对象,所以还可以通过for循环遍历List集合,例如遍历上面代码中的List集合的代码如下:

for (int i = 0; i < list.size(); i++) {
	System.out.println(list.get(i));// 利用get(int index)方法获得指定索引位置的对象
}

package com.mwq;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Iterator;
import java.util.List;
public class TestCollection {
	public static void main(String[] args) {
		System.out.println("开始:");
		String a = "A", b = "B", c = "C", d = "D", e = "E";
		List<String> list = new LinkedList<String>();
		list.add(a);
		list.add(e);
		list.add(d);
		list.set(1, b);// 将索引位置为1的对象e修改为对象b
		list.add(2, c);// 将对象c添加到索引位置为2的位置
		Iterator<String> it = list.iterator();
		while (it.hasNext()) {
			System.out.println(it.next());
		}	
//                 for (int i = 0; i < list.size(); i++) {
//                       System.out.println(list.get(i));// 利用get(int index)方法获得指定索引位置的对象
//          	}
		System.out.println("结束!");
	}
}


2.indexOf(Object obj)方法和lastIndexOf(Object obj)方法的区别
在使用List集合时需要注意区分indexOf(Object obj)方法和lastIndexOf(Object obj)方法,前者是获得指定对象的最小的索引位置,而后者是获得指定对象的最大的索引位置,前提条件是指定的对象在List集合中具有重复的对象,否则如果在List集合中有且仅有一个指定的对象,则通过这两个方法获得的索引位置是相同的,例如执行下面的代码:
public static void main(String[] args) {
	String a = "A", b = "B", c = "C", d = "D", repeat = "Repeat";
	List<String> list = new ArrayList<String>();
	list.add(a);          // 索引位置为 0
	list.add(repeat);      // 索引位置为 1
	list.add(b);          // 索引位置为 2
	list.add(repeat);      // 索引位置为 3 
	list.add(c);          // 索引位置为 4
	list.add(repeat);      // 索引位置为 5
	list.add(d);          // 索引位置为 6
	System.out.println(list.indexOf(repeat));
	System.out.println(list.lastIndexOf(repeat));
	System.out.println(list.indexOf(b));
	System.out.println(list.lastIndexOf(b));
}

package com.mwq;
import java.util.ArrayList;
import java.util.List;
public class TestCollection {
	public static void main(String[] args) {
		System.out.println("开始:");
		String a = "A", b = "B", c = "C", d = "D", repeat = "Repeat";
		List<String> list = new ArrayList<String>();
		list.add(a); // 索引位置为 0
		list.add(repeat); // 索引位置为 1
		list.add(b); // 索引位置为 2
		list.add(repeat); // 索引位置为 3
		list.add(c); // 索引位置为 4
		list.add(repeat); // 索引位置为 5
		list.add(d); // 索引位置为 6
		System.out.println(list.indexOf(repeat));
		System.out.println(list.lastIndexOf(repeat));
		System.out.println(list.indexOf(b));
		System.out.println(list.lastIndexOf(b));
		System.out.println("结束!");
	}
}
在控制台将输出如下信息:
1
5
2
2

3.subList(int fromIndex, int toIndex)方法
在使用subList(int fromIndex, int toIndex)方法截取现有List集合中的部分对象生成新的List集合时,需要注意的是,新生成的集合中包含起始索引位置代表的对象,但是不包含终止索引位置代表的对象,例如执行下面的代码:

public static void main(String[] args) {
	String a = "A", b = "B", c = "C", d = "D", e = "E";
	List<String> list = new ArrayList<String>();
	list.add(a);          // 索引位置为 0
	list.add(b);          // 索引位置为 1
	list.add(c);          // 索引位置为 2
	list.add(d);          // 索引位置为 3
	list.add(e);          // 索引位置为 4
	list = list.subList(1, 3);// 利用从索引位置 1 到 3 的对象重新生成一个List集合
	for (int i = 0; i < list.size(); i++) {
		System.out.println(list.get(i));
	}
}
package com.mwq;
import java.util.ArrayList;
import java.util.List;
public class TestCollection {
	public static void main(String[] args) {
		System.out.println("开始:");
		String a = "A", b = "B", c = "C", d = "D", e = "E";
		List<String> list = new ArrayList<String>();
		list.add(a); // 索引位置为 0
		list.add(b); // 索引位置为 1
		list.add(c); // 索引位置为 2
		list.add(d); // 索引位置为 3
		list.add(e); // 索引位置为 4
		list = list.subList(1, 3);// 利用从索引位置 1 到 3 的对象重新生成一个List集合
		for (int i = 0; i < list.size(); i++) {
			System.out.println(list.get(i));
		}
		System.out.println("结束!");
	}
}
在控制台将输出如下信息:
B
C


list中可以添加任何对象,我可以给你举个例子:
	class Person{
   		.....
	}

上面定义了一个Person类,下面看好如何使用List
	Person p1=new Person();
	Person p2=new Person();
	List list=new ArrayList();
	list.add(p1);
	list.add(p2);//这里是将对象加入到list中
	for(int i=0;i<list.size();i++){//利用循环,将person对象全部一一取出
  		  Person p=(Person)list.get(i);//注意,这里一定要强制类型转换,因为List中取出的对象都是Object类型的,希望对你有所帮助    
	}


<think>好的,我需要分析用户提供的Java代码,并解释如何将其转换为FreeMarker模板(FTL)中的实现,特别是使用“挡位”作为键的情况。首先,我需要理解用户代码的结构和目的。 用户代码中创建了一个`LinkedList<String>`名为`range`,然后声明了一个`HashMap`,键是`List<String>`,值是`List<Double>`。接着将`range`作为键,`changelist`作为值放入`map`中。随后遍历`map`的条目,打印出每个键(挡位)和对应的值(Changes)。 用户的问题是将这段Java代码的逻辑用FTL实现,尤其是处理挡位作为键的部分。我需要考虑如何在FTL中处理类似的数据结构,比如使用哈希映射和列表,以及如何遍历它们。 首先,FTL本身并不直接执行Java代码,但可以在模板中处理由Java控制器传递过来的数据模型。因此,用户需要在Java端准备数据,然后传递给FTL模板进行渲染。例如,在Spring MVC中,可以将`map`添加到模型对象中,然后在FTL中访问这个模型属性。 接下来,用户需要在FTL中遍历这个`map`。FTL的`<#list>`指令可以遍历集合,但需要注意键是`List<String>`的情况。由于FTL中列表作为键可能不太方便直接处理,可能需要将键转换为字符串表示,或者在Java端预先处理好数据结构,例如将挡位的列表转换为一个唯一的字符串键,如用逗号连接各个字符串元素。 此外,打印键和值时,需要确保它们正确转换为字符串。对于`List<String>`作为键,直接输出可能会调用`toString()`方法,显示为逗号分隔的字符串,如`[A, B]`。而`List<Double>`的值同样会以类似方式显示。 可能的陷阱包括在FTL中直接使用复杂对象作为键可能导致哈希不一致的问题,因此最好在Java端将键转换为不可变的类型,或者确保在FTL中正确处理。此外,FTL的数据类型和Java的映射需要正确对应,避免类型错误。 最后,需要提供一个示例的FTL代码,展示如何遍历这个`map`,并输出挡位和对应的Changes列表。同时,提醒用户注意在Java端正确传递数据模型,并处理可能的转换问题。</think>让我们逐步分析这段代码及其在FreeMarker(FTL)中的实现思路: 1. **Java代码功能解析**: - 创建链表`range`作为挡位标识 - 使用`List<String>`作为HashMap的键,存储对应挡位的`Double`型数值列表 - 遍历HashMap并打印键值对 2. **FTL实现核心要点**: ```ftl <#-- 假设 map 已从Java端传入模板上下文 --> <#assign gearMap = map> <#list gearMap?keys as key> <#assign value = gearMap[key]> 挡位:${key?join(", ")}, Changes: ${value?join(", ")} </#list> ``` 3. **关键注意事项**: - **键处理**:由于FTL中`List`作为哈希键可能引发哈希计算问题,建议: ```java // Java端建议转换为不可变键 Map<String, List<Double>> ftlMap = new HashMap<>(); ftlMap.put(String.join(",", range), changelist); ``` - **类型安全**:确保传入FTL的Map保持`List<String>` → `List<Double>`的原始结构 - **空值处理**:建议添加判空逻辑 ```ftl <#list gearMap?keys as key> <#if gearMap[key]??> ... </#if> </#list> ``` 4. **优化建议**: - **键序列化**:使用自定义对象封装挡位信息 - **数据校验**:添加类型检查 ```ftl <#if key?is_sequence && value?is_sequence> ... </#if> ``` 完整示例实现: ```ftl <#if gearMap??> <#list gearMap?keys as key> <#assign changes = gearMap[key]![]> 挡位:[${key?join(", ")}] 变化值:<#list changes as num>${num?string("0.00")}<#sep>, </#sep></#list> </#list> <#else> !警告:挡位数据未加载! </#if> ``` 建议配合Java端进行以下优化: ```java // 创建不可变键 public static String createGearKey(List<String> range) { return String.join("|", range); // 使用不易冲突的分隔符 } // 控制器层传递数据 model.addAttribute("gearMap", Collections.singletonMap(createGearKey(range), changelist)); ``` 这种实现方式既能保持数据结构特性,又能确保在模板引擎中的安全访问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值