最近很多小伙伴都在问java.util.List的remove()方法使用技巧这两个问题,那么本篇文章就来给大家详细解答一下,同时本文还将给你拓展'java.lang.NoClassDefFoundE
最近很多小伙伴都在问java.util.List 的 remove () 方法使用技巧这两个问题,那么本篇文章就来给大家详细解答一下,同时本文还将给你拓展'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”、com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问、guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换、Java List,List <?>,List
- java.util.List 的 remove () 方法使用技巧
- 'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”
- com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问
- guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换
- Java List,List <?>,List
,List 和List
java.util.List 的 remove () 方法使用技巧
一.list.remove (i)
public static void main(String[] args) {
List<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(2);
list.add(3);
list.add(3);
list.add(4);
for (int i=0; i<list.size(); i++) {
if (list.get(i) == 3) {
list.remove(i);//这样写不对,需要写成list.remove(i--)
}
}
System.out.println(list);
}
如果要遍历 list 进行过滤,比如过滤掉值为 3 的对象。本以为这代码再简单不过,可还是掉坑里了,上面的代码这样写的话,元素 3 是过滤不完的。只要 list 中有相邻 2 个相同的就过滤不完 List 调用 remove (index) 方法后,会移除 index 位置上的元素,index 之后的元素就全部依次左移,即索引依次 - 1 要保证能操作所有的数据,需要把 index-1,否则原来索引为 index+1 的元素就无法遍历到 (因为原来索引为 index+1 的数据,在执行移除操作后,索引变成 index 了,如果没有 index-1 的操作,就不会遍历到该元素,而是遍历该元素的下一个元素)。
同样,Map 通过 keySet () 或 entrySet () 遍历时,不能删除里面的元素,否则会报 java.util.ConcurrentModificationException
为了避免出现以上情况,需要对 List 或 Map 进行遍历且要进行删除操作时一定要使用迭代器 Iterator, 通过 iterator.remove () 来删除。
二。建议使用 iterator.remove 方法
if (null != list && list.size() > 0) {
Iterator it = list.iterator();
while(it.hasNext()){
Student stu = (Student)it.next();
if (stu.getStudentId() == studentId) {
it.remove(); //移除该对象
}
}
}
'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”
如何解决''java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”?
我收到此错误,我已阅读该错误以解决它我必须将 import java.util.Base64
替换为 import android.util.Base64
但在我的整个项目中我只发现 Base68 result = Base64.getEncoder().encodetoString(macData);
的唯一用法
我该如何解决?而且我不能用 android.util.Base.64 替换 java.util.Base64 因为这行代码在后端
解决方法
这很不幸 - 这意味着您正在使用某个库,而那个库正在尝试使用 /i
。 Android 选择了 Java 库,就像 android 发布时一样,现在已经是很久以前的事了。从那以后它们就没有真正更新过。 (那个 oracle v google 法庭案件可能没有帮助……)
java.util.Base64
已添加到 https://forge.autodesk.com/en/docs/design-automation/v3/reference/cmdLine/cmdLine-inventor/(有关此信息,请参阅 javadoc 中的“since”行;任何“1.6”或以下,或者如果没有“since”行,肯定可用在 android 上。其他东西通常不是)。 java 8 现在已经 7 岁了,因此不是专门为 android 设计的库越来越有可能开始使用这些非 android 库调用。
检查堆栈跟踪,您会找到正在执行此操作的库。恐怕除了停止使用这个库之外别无他法。您可以尝试在您的应用程序中粘贴 juBase64 impl,但这会相对棘手,因为这可能涉及一些法律问题,因此,要么没有人这样做,要么如果他们这样做,他们可能不会宣传如何。
您可以要求这个库使用第三方库来做 base64 工作,但他们可能不想这样做,这可能不是库无法在 android 上运行的唯一问题。
如果 android 变体是一个替代品,你可以重写这个库的类文件,但这也是一个有点笨拙、笨拙的概念,并不完全困难,但因为这不是一件正常的事情,而且通常积极不喜欢,我认为您无法轻松找到有关如何操作的文档。
因此,建议:尝试寻找另一个图书馆。
com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问
如何解决com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问
我在 VSCode 中编写了一些 kotlin 代码
其中之一是:
public void readCSV(String fileName) {
fileLocation = fileName;
File csvFile = new File(fileName);
Scanner sfile;
// noOfColumns = 0;
// noOfRows = 0;
data = new ArrayList<ArrayList>();
int colCounter = 0;
int rowCounter = 0;
try {
sfile = new Scanner(csvFile);
while (sfile.hasNextLine()) {
String aLine = sfile.nextLine();
Scanner sline = new Scanner(aLine);
sline.useDelimiter(",");
colCounter = 0;
while (sline.hasNext()) {
if (rowCounter == 0)
data.add(new ArrayList<String>());
data.get(colCounter).add(sline.next());
colCounter++;
}
rowCounter++;
sline.close();
}
// noOfColumns = colCounter;
// noOfRows = rowCounter;
sfile.close();
} catch (FileNotFoundException e) {
System.out.println("File to read " + csvFile + " not found!");
}
}
当我运行它时,我得到:
fun main() {
println("Hello world")
}
它有效,但我无法隐藏或修复警告,我使用 JDK 15
我在 IntelliJ 上没有收到这些警告
guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换
昨天写了一博客《java:java.util.Map 和 java.util.Set 的 Key 类型转换》, 主要是想实现以 java.util.Map
Key 类型转换,今天有空有研究了一下 guava 的代码,发现基于 guava 提供的 API 也是可以实现 Key 类型转换的: 关键就是 Maps 提供了 uniqueIndex 方法,可以将 Map 转换成 Key 不同的 Map。
package net.gdface.facelog;
import static com.google.common.base.Preconditions.checkNotNull;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import org.junit.Test;
import com.google.common.base.Function;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Iterators;
import com.google.common.collect.Maps;
import com.google.common.collect.Maps.EntryTransformer;
public class TestTransform {
/**
* convert {@code Map<K1,V>} to {@code Map<K2,V>}
* @return {@linkplain ImmutableMap}
*/
public static final <K1,K2,V>Map<K2,V> transform(Map<K1,V>fromMap,final Function<K1,K2>transformer){
checkNotNull(fromMap,"fromMap is null");
checkNotNull(transformer,"transformer is null");
// 新的Map对象Key类型已经是K2了,只是Value类型成了Entry
ImmutableMap<K2, Entry<K1, V>> k2Entry = Maps.uniqueIndex(fromMap.entrySet(), new Function<Entry<K1, V>,K2>(){
@Override
public K2 apply(Entry<K1, V> input) {
return transformer.apply(input.getKey());
}});
// 再做一次转换将Entry<K1, V>转换成V,这个过程并没有创建新的Map,只是创建了k2Entry的代理对象
Map<K2, V> k2V = Maps.transformEntries(k2Entry, new EntryTransformer<K2,Entry<K1,V>,V>(){
@Override
public V transformEntry(K2 key, Entry<K1, V> value) {
return value.getValue();
}});
return k2V;
}
/**
* convert {@code Set<E1>} to {@code Set<E2>}
* @return {@link ImmutableSet}
*/
public static final <E1,E2>Set<E2> transform(final Set<E1>fromSet,final Function<E1,E2>transformer){
checkNotNull(fromSet,"fromMap is null");
checkNotNull(transformer,"transformer is null");
return ImmutableSet.copyOf(Iterators.transform(fromSet.iterator(), transformer));
}
@Test
public void test() {
Map<String, String> m1 = Maps.<String,String>newLinkedHashMap();
m1.put("1", "apple");
m1.put("2", "orangle");
m1.put("3", "banana");
System.out.println(m1);
Map<Integer, String> m2 = transform(m1, new Function<String,Integer>(){
@Override
public Integer apply(String input) {
return Integer.valueOf(input);
}});
System.out.println(m2.toString());
}
}
复制
注意: 这个方法相比上篇博客中的方法要简单的多但是有区别的: 返回的 Map 对象是一个新的对象,与原 Map 对象没有任何关联,并且是不可变的 (immutable)。 而上一篇博客中的方法返回的 Map 对象则是原对象的代理对象,并且是可变的 (mutable),对新对象的任何操作实际都是对原对象的操作。
Java List,List <?>,List ,List 和List
有什么区别List,List<?>,List<T>,List<E>
,和List<Object>
?
1. List
List
:是原始类型,因此不是typesafe
。仅在转换不良时才会生成运行时错误。当强制转换错误时,我们需要一个编译时错误。不建议使用。
2. List<?>
List<?>
是一个无界通配符。但是我不确定它是做什么用的吗?我可以打印一个List<?>
没有问题的文件:
public static void test(List<?> list){ System.out.println(list); // Works}
为什么我不能向中添加项目List<?>
?
public static void test(List<?> list){ list.add(new Long(2)); // Error list.add("2"); // Error System.out.println(list);}
3. List
public static void test(List<T> list){ // T cannot be resolved System.out.println(list);}
我不明白这种语法。我看到了这样的东西,它的工作原理是:
public <T> T[] toArray(T[] a){ return a; }
有时候,我看<T>
,或者<E>
,或者<U>
,<T,E>
。它们都是相同的还是代表不同的东西?
4.List
答案1
小编典典1)正确
2)你可以将其视为“只读”列表,而不关心项目的类型。例如,可以由返回列表长度的方法使用。
3)T,E和U相同,但是人们倾向于使用T作为类型,E表示Element,V表示值,K表示键。编译的方法表示它接受了某种类型的数组,并返回了相同类型的数组。
4)你不能混合桔子和苹果。如果可以将字符串列表传递给需要对象列表的方法,则可以将对象添加到字符串列表中。(并非所有对象都是字符串)
我们今天的关于java.util.List 的 remove () 方法使用技巧的分享已经告一段落,感谢您的关注,如果您想了解更多关于'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”、com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问、guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换、Java List,List <?>,List
本文标签: