jjzjj

java - Java Lambda 表达式是否利用 "Hidden"或本地包导入?

coder 2024-03-18 原文

这个问题是关于 lambda 表达式似乎使用的 Java 包的明显“隐藏”或本地导入。

以下示例代码编译并运行良好(它仅列出给定目录中的文件):

package com.mbm.stockbot;

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;

public class Temp2 {
    public static void main(String[] args) {
        Temp2 t = new Temp2();
        t.readDir();
    }

    public void readDir() {
        try {
            Files.walk(Paths.get("C:/Users/mbmas_000/Downloads/SEC Edgar"), 1).forEach(filePath -> {
                if (Files.isRegularFile(filePath)) {
                    System.out.println(filePath);
                }
            });
        } catch (IOException e1) {
            e1.printStackTrace();
        }
    }
}

注意变量filePathPath的实例,我认为它的实现包含在包java.nio.file.Path中,虽然没有针对该包的 import

现在,如果我做一个小修改,比如将对 System.out.println 的调用重构为它自己的方法:

package com.mbm.stockbot;

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

public class Temp2 {

    public static void main(String[] args) {
        Temp2 t = new Temp2();
        t.readDir();
    }

    public void readDir() {
        try {
            Files.walk(Paths.get("C:/Users/mbmas_000/Downloads/SEC Edgar"), 1).forEach(filePath -> {
                if (Files.isRegularFile(filePath)) {
                    printPath(filePath);
                }
            });
        } catch (IOException e1) {
            e1.printStackTrace();
        }
    }

    public void printPath(Path passedFilePath) {
        System.out.println(passedFilePath);
    }
}

我现在必须“导入”import java.nio.file.Path,否则会出现编译错误。

所以我的问题是:

  1. 如果 filePath 确实是 java.nio.file.Path 的一个实例,为什么不需要我需要导入它在第一个示例中,并且

  2. 如果使用 lambda 表达式“在幕后”执行导入,那么为什么我需要在创建采用的方法时添加 import Path 的实例作为参数?

可用于调用 filePathpassedFilePath 的方法是相同的,这使我相信它们都是 java.nio.file.Path<>.

最佳答案

import声明并不意味着声明您的代码正在使用哪些类;他们只是声明使用什么来解析不合格的标识符。因此,如果您使用不合格的标识符 Path在你的代码中你必须使用 import java.nio.file.Path;声明它应该解析为这个限定类型。顺便说一句,这不是解析名称的唯一方法。名称也可以通过类继承来解析,例如如果它们匹配继承成员类的简单名称。

如果您隐式使用类型而不引用其名称,则不需要 import声明,这不仅限于 lambda 表达式,它甚至不是 Java 8 的特殊功能。例如。与

Files.walk(Paths.get("C:/Users/mbmas_000/Downloads/SEC Edgar"), 1)

您已经在使用 Path隐式输入,因为它是 Paths.get 的返回类型参数类型为 Files.walk ,换句话说,您接收到 java.nio.file.Path 的实例并在不引用其类型名称的情况下将其传递给另一个方法,因此您不需要 import .此外,您正在调用接受任意数量的 FileVisitOption 的可变参数方法。实例。您没有指定任何内容,因此您的代码将创建一个零长度 FileVisitOption[]数组并将其传递给 Files.walk , 同样,没有 import .

通过改进的类型推断,还有另一种可能性可以在不引用其名称的情况下使用类型,例如如果你打电话:

Files.newByteChannel(path, new HashSet<>());

您不仅创建了零长度 FileAttribute[] varargs 参数的数组,而不按名称引用此类型,您还创建了一个 HashSet<OpenOption>不引用类型 OpenOption按名字。所以这也不需要,导入 java.nio.file.attribute.FileAttribute也不java.nio.file.OpenOption .


所以最重要的是,你是否需要 import不依赖于类型的使用,而是取决于您是否通过其简单名称来引用它(并且有不止一种使用类型而不通过名称引用它的方法)。在您的第二个示例中,您指的是名称 Path在你的方法中 printPath(Path passedFilePath) ;如果将其更改为 printPath(Object passedFilePath) , 一切都将在没有显式 import 的情况下再次运行的 java.nio.file.Path .

关于java - Java Lambda 表达式是否利用 "Hidden"或本地包导入?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28180695/

有关java - Java Lambda 表达式是否利用 "Hidden"或本地包导入?的更多相关文章

  1. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  2. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  3. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  4. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  5. ruby 正则表达式 - 如何替换字符串中匹配项的第 n 个实例 - 2

    在我的应用程序中,我需要能够找到所有数字子字符串,然后扫描每个子字符串,找到第一个匹配范围(例如5到15之间)的子字符串,并将该实例替换为另一个字符串“X”。我的测试字符串s="1foo100bar10gee1"我的初始模式是1个或多个数字的任何字符串,例如,re=Regexp.new(/\d+/)matches=s.scan(re)给出["1","100","10","1"]如果我想用“X”替换第N个匹配项,并且只替换第N个匹配项,我该怎么做?例如,如果我想替换第三个匹配项“10”(匹配项[2]),我不能只说s[matches[2]]="X"因为它做了两次替换“1fooX0barXg

  6. ruby - 检查数组是否在增加 - 2

    这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife

  7. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  8. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  9. ruby - 检查字符串是否包含散列中的任何键并返回它包含的键的值 - 2

    我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案

  10. ruby-on-rails - 相关表上的范围为 "WHERE ... LIKE" - 2

    我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que

随机推荐