LinkinPark
当你的才华撑不起你野心时,那么请潜下心继续学习,心无旁骛,愿多年以后你们我都能成为自己想象的模样。

1,现在我们封装一个方法,来提供一个比较器,显然比较器是拥有两个参数的--用来比较的两个值。
public class Linkin
{
	public static String[] sort(String[] array)
	{
		Arrays.sort(array, (s, t) -> Integer.compare(s.length(), t.length()));
		return array;
	}


	public static void main(String[] args)
	{
		String[] array = { "111111", "11", "111" };
		Arrays.stream(sort(array)).forEach(System.out::println);
	}
}


2,现在我们再封装一个方法,重复一个迭代来计算输出迭代次数。
public class Linkin
{
	public static void repeat(int n, IntConsumer action)
	{
		for (int i = 0; i < n; i++)
		{
			action.accept(i);
		}
	}


	public static void main(String[] args)
	{
		repeat(5, System.out::println);
	}
}


3,上面的2个情景我们使用lambda表达式都为其传入了参数,一般来说,我们在设计算法时,会希望它可以将全部所需的信息都作为参数传递进来。举个例子,当我们在编辑一个图片的时候,很可能需要用户提供一个计算相熟颜色的函数,这种函数可能不仅需要知道当前的颜色,还要知道像素在图片中的位置,或者相邻的像素是什么。但是,如果这些参数很少用到,那么我们就可以考虑提供第2个版本,不强制用户接受那些不需要的参数。


比如上面的第2个情节中,我们现在暂时不管迭代了次数了,不用来做计算了,那么我们现在就可以不需要传入这些参数用来做处理,我们直接换一个函数式接口就OK了。代码如下:
public class Linkin
{
	public static void repeat(int n, Runnable action)
	{
		for (int i = 0; i < n; i++)
		{
			action.run();
		}
	}


	public static void main(String[] args)
	{
		repeat(5, ()->System.out.println("啦啦啦,这里来写自己的算法。。。"));
	}
}

posted on 2015-11-23 14:47  LinkinPark  阅读(619)  评论(0)    收藏  举报