GVKun编程网logo

java.util.Optional 学习笔记(java utility.readmenuselection)

3

在这篇文章中,我们将带领您了解java.util.Optional学习笔记的全貌,包括javautility.readmenuselection的相关情况。同时,我们还将为您介绍有关'java.lan

在这篇文章中,我们将带领您了解java.util.Optional 学习笔记的全貌,包括java utility.readmenuselection的相关情况。同时,我们还将为您介绍有关'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”、android – 解压缩zip文件给出“java.util.zip.ZipException:无法读取版本”或“java.util.ZipException无法读取本地标题版本45”、com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问、guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换的知识,以帮助您更好地理解这个主题。

本文目录一览:

java.util.Optional 学习笔记(java utility.readmenuselection)

java.util.Optional 学习笔记(java utility.readmenuselection)

java.util.Optional 是 Java 8 新增的类,作为一个持有实例的容器类,可以帮我们把判空的代码写得更优雅,并且该类还提供了一些实用的 api,官方文档在这里,接下来我们通过实战来学习吧:

### 三种 Optional 构造方法 ###
第一种. Optional.of (Object object):入参 object 不能为空,否则会抛出空指针异常,查看 Optional 源码发现会调用 Objects.requireNonNull 方法,里面有判空:

public static <T> T requireNonNull(T obj) {
   
   
   
        if (obj == null)
            throw new NullPointerException();
        return obj;
    }

第二种. Optional.ofNullable (Object object):入参 object 可以为空,如果 object 不为空,就创建一个 Optional 实例;如果 object 为空就返回一个 static fainal 的 Option 对象,注意这里不会新建 Option 实例,而是使用一个 static final 的实例 EMPTY,这里比较有意思的是泛型的问题,例如我需要两个 Optional 对象,类型分别是 String 和 Integer,代码如下:

Optional<String> optionalStr = Optional.ofNullable(null);
Optional<Integer> optionalInt = Optional.ofNullable(null);

类型不同又如何保证返回同一个对象呢?直接看 ofNullable 的源码,发现会调用 empty 方法:

public static<T> Optional<T> empty() {
   
   
   
        @SuppressWarnings("unchecked")
        Optional<T> t = (Optional<T>) EMPTY;
        return t;
    }

原来是通过强制转换实现的,再看 EMPTY 对象:

private static final Optional<?> EMPTY = new Optional<>();

是通过 "?" 声明的;

第三种. Optional.empty ():就是上面分析 Optional.ofNullable 的时候用到的 empty 方法,直接返回一个 static final 的实例 EMPTY;

Optional.of () 方法的用法有点像断言,对象为空的时候代表着某种业务上不可接受的异常,需要尽早处理,并且业务拒绝执行,这种场景下可以使用 Optional.of;

接下来我们开始实战吧;

### 例子中用到的对象:Student###
Student 是个普通的 bean,有三个字段和对应的 get&set 方法

package com.bolingcavalry;

/**
 * @author willzhao
 * @version V1.0
 * @Description: 一个普通的bean
 * @email zq2599@gmail.com
 * @Date 2017/8/26 下午11:23
 */
public class Student {
   
   
   
    private int id;

    private String name;

    private int age;

    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 int getAge() {
   
   
   
        return age;
    }

    public void setAge(int age) {
   
   
   
        this.age = age;
    }

    public Student(int id, String name, int age) {
   
   
   
        this.id = id;
        this.name = name;
        this.age = age;
    }
}

###Optional.ofNullable 的用法 ###
下面举例说明最常用的 Optional.ofNullable,我们打算根据名称从其他系统获取 student 对象,如果对象为空就返回默认对象,先看不用 Optional 的时候我们平常是怎么写的,如下代码所示,标准的 if&else 判断:

	private Student queryById(int id){
   
   
   
        //TODO 这里模拟从数据库查询
        return null;
    }

    public Student getStudent(int id){
   
   
   
        Student student = queryById(id));

        //如果为空就返回DEFAULT对象
        return student==null ? DEFAULT : student;
    }

用 Optional 之后,如下所示,不需要通过判空来避免空指针异常了:

private Student queryById(int id){
   
   
   
        //TODO 这里模拟从数据库查询
        return null;
    }
    
    public Student getStudent(int id){
   
   
   
        Optional<Student> optional = Optional.ofNullable(queryById(id));

        //如果为空就返回DEFAULT对象
        return optional.orElse(DEFAULT);
    }

orElse 方法可以指定一个 value 为空时的返回对象,如果这个对象需要调用方法才能获取 (例如我们拿不到 DEFAULT 对象,要通过 getDefault () 方法才能拿到),这是就需要 orElseGet 方法来达到目的,如下:

private Student queryById(int id){
   
   
   
	//TODO 这里模拟从数据库查询
    return null;
}

private Student getDefault(){
   
   
   
	return DEFAULT;
}

public Student getStudent(int id){
   
   
   
	Optional<Student> optional = Optional.ofNullable(queryById(id));

	//如果为空就返回DEFAULT对象
    return optional.orElseGet(() -> getDefault());
}

###Optional 的 map 方法 ###
假如我们的需求是 student 对象非空就返回 name 的大写,如果 student 对象为空就返回 "invalid",在没有 Optional 的时候写法如下,除了检查 student 变量是否为空,还要检查 name 是否为空:

private Student queryById(int id){
   
   
   
        //TODO 这里模拟从数据库查询
        return null;
}

public String getStudentUpperName(int id){
   
   
   
	Student student = queryById(id);
	if(student!=null && student.getName()!=null){
   
   
   
		return student.getName().toUpperCase();
    }

    return "invalid";
}

用了 Optional 可以这么写:

private Student queryById(int id){
   
   
   
	//TODO 这里模拟从数据库查询
	return null;
}

public String getStudentUpperName(int id){
   
   
   
	Optional<Student> optional = Optional.ofNullable(queryById(id));

    return optional.map(student -> student.getName())
                   .map(name -> name.toUpperCase())
                   .orElse("invalid");
}

由以上代码可以看到,map 可以将一个 Optional 对象转换成另一个,第一次是将 Optional 转换成了 Optional,第二次是将 Optional 转成了另一个 Optional,只是这次将字符串换成了大写;

本次实战的源码已经上传到 git 上,地址是 git@github.com:zq2599/blog_demos.git,里面有多个工程,本次用到的是 optionaldemo,如下图红框所示:

这里写图片描述

以上就是 Optional 的基本用法,对 Optional 的使用是在习惯上对之前判空写法的挑战,但可以试着去习惯这个简单优雅的小工具;

欢迎关注我的公众号

在这里插入图片描述

本文分享 CSDN - 程序员欣宸。
如有侵权,请联系 support@oschina.cn 删除。
本文参与 “OSC 源创计划”,欢迎正在阅读的你也加入,一起分享。

'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”

'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 变体是一个替代品,你可以重写这个库的类文件,但这也是一个有点笨拙、笨拙的概念,并不完全困难,但因为这不是一件正常的事情,而且通常积极不喜欢,我认为您无法轻松找到有关如何操作的文档。

因此,建议:尝试寻找另一个图书馆。

android – 解压缩zip文件给出“java.util.zip.ZipException:无法读取版本”或“java.util.ZipException无法读取本地标题版本45”

android – 解压缩zip文件给出“java.util.zip.ZipException:无法读取版本”或“java.util.ZipException无法读取本地标题版本45”

我想提取一个普通的zip文件,但它仍然失败.
这是我现在使用的代码:

private File downloadpath = new File(Environment.getExternalStorageDirectory() + "/Test/file.zip");
private File unzipLoc = new File(Environment.getExternalStorageDirectory() + "/Test/");
        FileInputStream fin = new FileInputStream(downloadpath); 
        ZipInputStream zin = new ZipInputStream(fin);
        ZipEntry ze = null; 
        while ((ze = zin.getNextEntry()) != null) 
        { 
            FileOutputStream fout = new FileOutputStream(unzipLoc + ze.getName()); 
            for (int c = zin.read(); c != -1; c = zin.read()) 
            { 
                fout.write(c); 
            } 

            zin.closeEntry(); 
            fout.close(); 
        } 
        zin.close(); 

它在’zin.getNextEntry()’部分失败.
错误:java.util.zip.ZipException:无法读取版本
有任何想法吗?谢谢!

解决方法:

看起来你的zip文件比你的’解压缩库’更新.

如果您阅读来源:

ZipInputStream(搜索新的ZipException(“无法读取版本”))

它显示它检查zip文件版本.然后查看Wikipedia它显示这是提取zip所需的最低版本.

检查您的zip文件并使用较低版本的zip软件重新保存/再次压缩,无需压缩即可测试

或者更新你的Zip库(你不能使用内部的android zip库).

com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问

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 类型转换

guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换

昨天写了一博客《java:java.util.Map 和 java.util.Set 的 Key 类型转换》, 主要是想实现以 java.util.MapKey 类型转换,今天有空有研究了一下 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.util.Optional 学习笔记java utility.readmenuselection的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于'java.lang.NoClassDefFoundError 由 java.lang.ClassNotFoundException 引起的 Ljava/util/Base64 解析失败 未找到类“java.util.Base64”、android – 解压缩zip文件给出“java.util.zip.ZipException:无法读取版本”或“java.util.ZipException无法读取本地标题版本45”、com.intellij.util.ReflectionUtil 对方法 java.util.ResourceBundle.setParent(java.util.ResourceBundle) 的非法反射访问、guava:java:java.util.Map 和 java.util.Set 的 Key 类型转换的相关信息,请在本站寻找。

本文标签: