Lambda表达式函数式编程

时间:2015-06-13 17:00:14

标签: java regex lambda functional-programming

我必须使用lambda表达式为大学编写正则表达式。我在方法中遇到了两种方法。

这是我的代码:

static String ausdruck = "abcd";

public static Function<String, String> Char = (c) -> {
    return (ausdruck.startsWith(c)) ? ausdruck = ausdruck.substring(1,
            ausdruck.length()) : "Value Error";
};

public static BiFunction<Function<String, String>, 
                         Function<String, String>, 
                         Function<String, String>> 
                And = (f1, f2) -> {return null;};

我想在And方法中执行的操作是:Char(Char.apply("a")) - &gt;我想以f2作为参数调用函数f1。 和方法的召唤必须看起来像:

And.apply(Char.apply("a"), Char.apply("b"));

2 个答案:

答案 0 :(得分:1)

我想这就是你想要的

    Func<Str,Str> f = and( comsume("a"), consume("b") );
    f.apply("abcd"); // "cd"


Func<Str,Str> consume(String x)
    return input->{ 
        if(input.startsWith(x)) return input.substring(x.length());
        else throws new IllegalArgument()
    };


Func<Str,Str> and(Fun<Str,Str> f1, Func<Str,Str> f2)
    return input-> f2.apply(f1.apply(input))

and不是必需的,请参阅Function.andThen方法

    f = consume("a").andThen( consume("b) )

不幸的是,没有“咖喱”;否则,我们可以这样做

    f = consume2.curry("a") .andThen (  consume2.curry("b") );

static BiFunc<Str,Str,Str> consume2 = (input,x)-> {...return input.substring(x.length()); ..

如果您使用咖喱等必需的方法设计自己的功能界面,情况会更好。

interface F1
    String apply(String);
    F1 and(F1);

interface F2
    String apply(String,String);
    F1 curry(String);

答案 1 :(得分:0)

如果我正确理解了这个问题,你想创建一个函数来编译一个新函数,用另一个函数的结果执行一个函数。在lambda中执行此操作的最佳方法是返回一个新的lambda。

尝试这样的事情:

BiFunction<Function<String, String>, Function<String, String>, Function<String, String>> compose =
            (f1, f2) -> (a -> f2.apply(f1.apply(a)));

示例:

Function<String, String> upper = s -> s.toUpperCase();
Function<String, String> twice = s -> s + s;
Function<String, String> upperTwice = compose.apply(upper, twice);
System.out.println(upperTwice.apply("foo"));

输出为FOOFOO

关于你的具体例子

  

和方法的调用必须如下:   And.apply(Char.apply("a"), Char.apply("b");

我不确切地知道你要做什么,但鉴于你目前的Char实施,我不认为这会有效。您似乎想要组建一个lambda来移除a与另一个移除b,但Char.apply("a")不会创建另一个函数,但实际上从您的{"a"移除ausdruck {1}}字符串!相反,你的Char lambda也应该返回另一个lambda,而lambda不应该修改一些static变量,而是接受并返回另一个String参数。

Function<String, Function<String, String>> stripChar = 
            c -> (s -> s.startsWith(c) ? s.substring(1) : "ERROR");
Function<String, String> stripAandC = compose.apply(stripChar.apply("c"), stripChar.apply("a"));
System.out.println(stripAandC.apply("cash"));

输出为sh

最后,如果您想要使用除String以外的任何其他内容,将compose作为实际方法而不是lambda可能是有意义的,因此您可以使用泛型。此外,您可以使用andThen

使这更简单一些
public static <A, B, C> Function<A, C> compose(Function<A, B> f1, Function<B,C> f2){
    return f1.andThen(f2);
}