Difference between revisions of "Lambda Demos"

From CSE231 Wiki
Jump to navigation Jump to search
Line 7: Line 7:
 
=Code To Investigate=
 
=Code To Investigate=
 
==fork join==
 
==fork join==
  <nowiki> <nowiki>System.out.println("start");
+
  <nowiki>System.out.println("start");
  
 
Future<Void> apples = void_fork(() -> {
 
Future<Void> apples = void_fork(() -> {
Line 30: Line 30:
 
System.out.println("stop");</nowiki>
 
System.out.println("stop");</nowiki>
  
{{CodeToInvestigate|LambdasAsyncAndFinishExample|main|lambda.forkjoin.demo|demo}}
+
{{CodeToInvestigate|LambdasForkJoinExample|main|lambda.forkjoin.demo|demo}}
  
{{CodeToInvestigate|AnonymousInnerClassesAsyncAndFinishExample|main|lambda.forkjoin.demo|demo}}
+
{{CodeToInvestigate|AnonymousInnerClassesForkJoinExample|main|lambda.forkjoin.demo|demo}}
  
{{CodeToInvestigate|NamedClassesAsyncAndFinishExample|main|lambda.forkjoin.demo|demo}}
+
{{CodeToInvestigate|NamedClassesForkJoinExample|main|lambda.forkjoin.demo|demo}}
  
 
==x10.finish==
 
==x10.finish==

Revision as of 05:33, 12 February 2022

Motivation

JDK 8 added lambdas to alleviate the bulkiness of anonymous inner classes. We use lambdas heavily in 231.

Background

Lambda Expressions

Code To Investigate

fork join

System.out.println("start");

Future<Void> apples = void_fork(() -> {
	sleepRandom(1_000);
	System.out.println("-apples");
});
Future<Void> oranges = void_fork(() -> {
	sleepRandom(1_000);
	System.out.println("--oranges");
});
Future<Void> bananas = void_fork(() -> {
	sleepRandom(1_000);
	System.out.println("---bananas");
});
Future<Void> mangoes = void_fork(() -> {
	sleepRandom(1_000);
	System.out.println("----mangoes");
});

join(apples, oranges, bananas, mangoes);

System.out.println("stop");
class: LambdasForkJoinExample.java DEMO: Java.png
methods: main
package: lambda.forkjoin.demo
source folder: src/demo/java
class: AnonymousInnerClassesForkJoinExample.java DEMO: Java.png
methods: main
package: lambda.forkjoin.demo
source folder: src/demo/java
class: NamedClassesForkJoinExample.java DEMO: Java.png
methods: main
package: lambda.forkjoin.demo
source folder: src/demo/java

x10.finish

class: LambdasAsyncAndFinishExample.java DEMO: Java.png
methods: main
package: lambda.demo.asyncfinish
source folder: src//java
class: AnonymousInnerClassesAsyncAndFinishExample.java DEMO: Java.png
methods: main
package: lambda.demo.asyncfinish
source folder: src//java
class: NamedClassesAsyncAndFinishExample.java DEMO: Java.png
methods: main
package: lambda.demo.asyncfinish
source folder: src//java

compute

String text = "abracadabra";
// NOTE: we use a TreeMap<K,V> since it is sorted producing consistent output
Map<Character, Integer> mapCharacterToCount = new TreeMap<>();
for( char ch : text.toCharArray() ) {
	// https://docs.oracle.com/javase/8/docs/api/java/util/Map.html#compute-K-java.util.function.BiFunction-
	mapCharacterToCount.compute(ch, (Character character, Integer count)-> {
		if( count != null ) {
			//we have associated character before
			return count+1;
		} else {
			//first encounter with character
			return 1;
		}
	});
}
for( Entry<Character, Integer> entry : mapCharacterToCount.entrySet() ) {
	System.out.println(entry);
}
class: LambdasMapComputeExample.java DEMO: Java.png
methods: demo
package: lambda.demo.compute
source folder: src//java
class: AnonymousInnerClassesMapComputeExample.java DEMO: Java.png
methods: demo
package: lambda.demo.compute
source folder: src//java
class: NamedClassesMapComputeExample.java DEMO: Java.png
methods: demo
package: lambda.demo.compute
source folder: src//java

user interface

LambdaViz.png

buttonI.setOnAction((ActionEvent e) -> {
	System.out.println("entering lambda");
	System.out.println("    " + accessible_within_lambda_i + "            (note: runtime stack with local variable i long since popped)");
	System.out.println(" leaving lambda");
	System.out.println();
});
class: FxLambdaDemoApp.java VIZ
package: lambda.demo.viz
source folder: student/src//java