聊一聊JavaScript和Java、C#的“箭头函数”(一)

简介: ES6 中引入了箭头函数,这也是现在前端面试几乎必考的内容(没考箭头函数,我都不好意思说自己是面试官,哈哈,开个玩笑)。有人问我,箭头函数是个什么东西?我跟他说,就像Java和C#中的lambda。

1. 举个简单的栗子:

1.1 JavaScript:

let func = (s)=> { console.log(s); };
func("hello world");

1.2 Java:

interface Operate {
    void doSomething(String str);
    // void doSomething1(); 不可以有两个方法
}
public static void main(String[] args) {
    Operate func = (String s)->{ System.out.println(s);};
    func.doSomething("hello world");
}

1.3 C#:

var func = (string s)=> { Console.WriteLine(s); };
func("hello world");

1.4 分析

可以看到,写法非常类似,尤其是Js和C#。 变量func可以被当做一个函数来使用。


那么用于承接这个匿名方法的变量实际是什么?


JavaScript: 就是一个js中的function


Java: 在例子中,有点容易迷惑,明明是将lambda赋值给了一个接口类型。但最终调用的时候又要调用该接口的doSomething方法。而且这个接口只能有一个对应的方法,多了会报错。


Java10中也提供了var关键字,但遗憾的是也不能被用于这样lambda赋值的情况。


C#: 实际上是一个委托类型,例如:

delegate void doSomething(string str);
public static void Main(string[] args) {
    doSomething func = (string s) => { Console.WriteLine(s); };
    func("hello world");
}

这样看和Java有点像了,但定义的仍然是一个方法,而不是一个接口中有一个同样类型的方法。

  • 如果在c语言中我们会用一个指向函数的指针。

2. 对函数外变量的引用

在上一节的例子中,“hello world”是以参数的形式传递到方法中的,那么,是否可以直接引用外部的方法呢?

当然是可以的,改造一下上面的例子:

2.1 JavaScript:

let str = ",圣诞快乐。";
let func = (s)=> { 
    console.log(s + str); 
    str = ",春节快乐。"
};
str = ",元旦快乐。"
func("hello world");
func("hello world");

2.2 Java:

    interface Operate {
        void doSomething(String str);
        // void doSomething1(); 不可以有两个方法
    }
    public static void main(String[] args) {
        final String str = ",圣诞快乐";
        Operate func = (String s)->{
            System.out.println(s + str);
            //str = ",春节快乐。";
        };
        //str = ",元旦快乐。"
        func.doSomething("hello world");
    }

2.3 C#:

var str = ",圣诞快乐。";
var func = (string s) => { 
    Console.WriteLine(s + str );
    str = ",春节快乐。";
};
str = ",元旦快乐。";
func("hello world");
func("hello world");

2.4 分析

  • JavaScript 和C# 的结果是一样的,输出结果为:
hello world,元旦快乐。 
hello world,春节快乐。
  • 可见,在函数执行的时候,会取当时str的值。在函数定义的时候,虽然引用了变量str,但不是此时固定了str的值。
    在函数中改变了str的值,会改变外部str的值。
  • Java的例子中,要求str是final的才行,所以是无法对str改变的。
目录
相关文章
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
42 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
2月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
2月前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
28 1
|
2月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
42 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
存储 JavaScript 前端开发
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
40 0
|
7月前
|
JavaScript 前端开发 Java
Java和JavaScript的区别
【4月更文挑战第8天】Java和JavaScript的区别
71 1
|
7月前
|
前端开发 JavaScript Java
Java与JavaScript的区别与联系:有人的地方就有江湖,有浏览器的地方就有JavaScript
Java与JavaScript的区别与联系:有人的地方就有江湖,有浏览器的地方就有JavaScript
391 0