जावा 8 - धाराएँ
स्ट्रीम जावा 8 में शुरू की गई एक नई अमूर्त परत है। स्ट्रीम का उपयोग करके, आप एसक्यूएल स्टेटमेंट के समान ही डिक्लेक्टिव तरीके से डेटा प्रोसेस कर सकते हैं। उदाहरण के लिए, निम्न SQL कथन पर विचार करें।
SELECT max(salary), employee_id, employee_name FROM Employee
उपरोक्त एसक्यूएल अभिव्यक्ति स्वचालित रूप से अधिकतम वेतनभोगी कर्मचारी के विवरण को लौटाता है, बिना डेवलपर के अंत में कोई संगणना किए बिना। जावा में संग्रह ढांचे का उपयोग करते हुए, एक डेवलपर को छोरों का उपयोग करना पड़ता है और बार-बार चेक करना पड़ता है। एक और चिंता दक्षता है; जैसा कि मल्टी-कोर प्रोसेसर आसानी से उपलब्ध हैं, एक जावा डेवलपर को समानांतर कोड प्रसंस्करण लिखना पड़ता है जो बहुत त्रुटि-प्रवण हो सकता है।
इस तरह के मुद्दों को हल करने के लिए, जावा 8 ने धारा की अवधारणा को पेश किया जो डेवलपर को इसके लिए कोई विशिष्ट कोड लिखने की आवश्यकता के बिना डेटा को घोषणात्मक रूप से संसाधित करने और मल्टीकोर आर्किटेक्चर का लाभ उठाने की अनुमति देता है।
स्ट्रीम क्या है?
स्ट्रीम एक स्रोत से वस्तुओं के अनुक्रम का प्रतिनिधित्व करता है, जो कुल संचालन का समर्थन करता है। एक स्ट्रीम की विशेषताएं निम्नलिखित हैं -
Sequence of elements- एक धारा क्रमबद्ध तरीके से विशिष्ट प्रकार के तत्वों का एक सेट प्रदान करती है। एक स्ट्रीम मांग पर तत्वों को प्राप्त / गणना करता है। यह तत्वों को कभी संग्रहीत नहीं करता है।
Source स्ट्रीम इनपुट के रूप में कलेक्शन, एरेज़ या I / O संसाधनों को लेती है।
Aggregate operations - स्ट्रीम फ़िल्टर, मानचित्र, सीमा, घटाना, ढूंढना, मिलान करना, और इसी तरह के कुल संचालन का समर्थन करता है।
Pipelining- अधिकांश स्ट्रीम ऑपरेशन स्वयं स्ट्रीम को लौटाते हैं ताकि उनका परिणाम पाइपलाइन किया जा सके। इन ऑपरेशनों को मध्यवर्ती संचालन कहा जाता है और उनका कार्य इनपुट लेना, उन्हें संसाधित करना और आउटपुट को लक्ष्य पर वापस करना है। इकट्ठा () विधि एक टर्मिनल ऑपरेशन है जो आम तौर पर स्ट्रीम के अंत को चिह्नित करने के लिए पाइपलाइनिंग ऑपरेशन के अंत में मौजूद होता है।
Automatic iterations स्ट्रीम ऑपरेशन, संग्रह के विपरीत स्रोत तत्वों पर आंतरिक रूप से पुनरावृत्तियां करते हैं, जहां स्पष्ट पुनरावृत्ति की आवश्यकता होती है।
उत्पन्न करने वाली धाराएँ
जावा 8 के साथ, संग्रह इंटरफ़ेस में एक स्ट्रीम उत्पन्न करने के दो तरीके हैं।
stream() - संग्रह को अपना स्रोत मानते हुए एक अनुक्रमिक धारा लौटाता है।
parallelStream() - संग्रह के स्रोत के रूप में विचार करते हुए एक समानांतर स्ट्रीम लौटाता है।
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());
प्रत्येक के लिए
स्ट्रीम ने धारा के प्रत्येक तत्व को पुनरावृत्त करने के लिए एक नई विधि 'forEach' प्रदान की है। निम्न कोड खंड दिखाता है कि forEach का उपयोग करके 10 यादृच्छिक संख्याओं को कैसे प्रिंट किया जाए।
Random random = new Random();
random.ints().limit(10).forEach(System.out::println);
नक्शा
'मैप' पद्धति का उपयोग प्रत्येक तत्व को उसके अनुरूप परिणाम के लिए मैप करने के लिए किया जाता है। निम्नलिखित कोड खंड मानचित्र का उपयोग करके संख्याओं के अनूठे वर्गों को प्रिंट करता है।
List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
//get list of unique squares
List<Integer> squaresList = numbers.stream().map( i -> i*i).distinct().collect(Collectors.toList());
फिल्टर
मापदंड के आधार पर तत्वों को खत्म करने के लिए 'फिल्टर' विधि का उपयोग किया जाता है। निम्नलिखित कोड खंड फिल्टर का उपयोग करके खाली तारों की एक गिनती प्रिंट करता है।
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
//get count of empty string
int count = strings.stream().filter(string -> string.isEmpty()).count();
सीमा
धारा के आकार को कम करने के लिए 'सीमा' विधि का उपयोग किया जाता है। निम्न कोड खंड दिखाता है कि सीमा का उपयोग करके 10 यादृच्छिक संख्या कैसे प्रिंट करें।
Random random = new Random();
random.ints().limit(10).forEach(System.out::println);
क्रमबद्ध
स्ट्रीम को सॉर्ट करने के लिए 'सॉर्टेड' पद्धति का उपयोग किया जाता है। निम्न कोड खंड दिखाता है कि क्रमबद्ध क्रम में 10 यादृच्छिक संख्याओं को कैसे प्रिंट किया जाए।
Random random = new Random();
random.ints().limit(10).sorted().forEach(System.out::println);
समानांतर प्रसंस्करण
समानांतर प्रसंस्करण के लिए धारा का विकल्प है। निम्नलिखित कोड खंड पर एक नज़र डालें जो समानांतर स्ट्र्रीम का उपयोग करके खाली तारों की एक गिनती प्रिंट करता है।
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
//get count of empty string
long count = strings.parallelStream().filter(string -> string.isEmpty()).count();
अनुक्रमिक और समानांतर धाराओं के बीच स्विच करना बहुत आसान है।
कलेक्टरों
एक धारा के तत्वों पर प्रसंस्करण के परिणाम को संयोजित करने के लिए कलेक्टरों का उपयोग किया जाता है। एक सूची या एक स्ट्रिंग वापस करने के लिए कलेक्टरों का उपयोग किया जा सकता है।
List<String>strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList());
System.out.println("Filtered List: " + filtered);
String mergedString = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.joining(", "));
System.out.println("Merged String: " + mergedString);
आंकड़े
जावा 8 के साथ, सांख्यिकी कलेक्टरों को सभी आंकड़ों की गणना करने के लिए पेश किया जाता है जब स्ट्रीम प्रसंस्करण किया जा रहा है।
List numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
IntSummaryStatistics stats = numbers.stream().mapToInt((x) -> x).summaryStatistics();
System.out.println("Highest number in List : " + stats.getMax());
System.out.println("Lowest number in List : " + stats.getMin());
System.out.println("Sum of all numbers : " + stats.getSum());
System.out.println("Average of all numbers : " + stats.getAverage());
स्ट्रीम उदाहरण
C: \> JAVA में अपनी पसंद के किसी भी संपादक का उपयोग करके निम्नलिखित जावा प्रोग्राम बनाएं।
Java8Tester.java
import java.util.ArrayList;
import java.util.Arrays;
import java.util.IntSummaryStatistics;
import java.util.List;
import java.util.Random;
import java.util.stream.Collectors;
import java.util.Map;
public class Java8Tester {
public static void main(String args[]) {
System.out.println("Using Java 7: ");
// Count empty strings
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
System.out.println("List: " +strings);
long count = getCountEmptyStringUsingJava7(strings);
System.out.println("Empty Strings: " + count);
count = getCountLength3UsingJava7(strings);
System.out.println("Strings of length 3: " + count);
//Eliminate empty string
List<String> filtered = deleteEmptyStringsUsingJava7(strings);
System.out.println("Filtered List: " + filtered);
//Eliminate empty string and join using comma.
String mergedString = getMergedStringUsingJava7(strings,", ");
System.out.println("Merged String: " + mergedString);
List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
//get list of square of distinct numbers
List<Integer> squaresList = getSquares(numbers);
System.out.println("Squares List: " + squaresList);
List<Integer> integers = Arrays.asList(1,2,13,4,15,6,17,8,19);
System.out.println("List: " +integers);
System.out.println("Highest number in List : " + getMax(integers));
System.out.println("Lowest number in List : " + getMin(integers));
System.out.println("Sum of all numbers : " + getSum(integers));
System.out.println("Average of all numbers : " + getAverage(integers));
System.out.println("Random Numbers: ");
//print ten random numbers
Random random = new Random();
for(int i = 0; i < 10; i++) {
System.out.println(random.nextInt());
}
System.out.println("Using Java 8: ");
System.out.println("List: " +strings);
count = strings.stream().filter(string->string.isEmpty()).count();
System.out.println("Empty Strings: " + count);
count = strings.stream().filter(string -> string.length() == 3).count();
System.out.println("Strings of length 3: " + count);
filtered = strings.stream().filter(string ->!string.isEmpty()).collect(Collectors.toList());
System.out.println("Filtered List: " + filtered);
mergedString = strings.stream().filter(string ->!string.isEmpty()).collect(Collectors.joining(", "));
System.out.println("Merged String: " + mergedString);
squaresList = numbers.stream().map( i ->i*i).distinct().collect(Collectors.toList());
System.out.println("Squares List: " + squaresList);
System.out.println("List: " +integers);
IntSummaryStatistics stats = integers.stream().mapToInt((x) ->x).summaryStatistics();
System.out.println("Highest number in List : " + stats.getMax());
System.out.println("Lowest number in List : " + stats.getMin());
System.out.println("Sum of all numbers : " + stats.getSum());
System.out.println("Average of all numbers : " + stats.getAverage());
System.out.println("Random Numbers: ");
random.ints().limit(10).sorted().forEach(System.out::println);
//parallel processing
count = strings.parallelStream().filter(string -> string.isEmpty()).count();
System.out.println("Empty Strings: " + count);
}
private static int getCountEmptyStringUsingJava7(List<String> strings) {
int count = 0;
for(String string: strings) {
if(string.isEmpty()) {
count++;
}
}
return count;
}
private static int getCountLength3UsingJava7(List<String> strings) {
int count = 0;
for(String string: strings) {
if(string.length() == 3) {
count++;
}
}
return count;
}
private static List<String> deleteEmptyStringsUsingJava7(List<String> strings) {
List<String> filteredList = new ArrayList<String>();
for(String string: strings) {
if(!string.isEmpty()) {
filteredList.add(string);
}
}
return filteredList;
}
private static String getMergedStringUsingJava7(List<String> strings, String separator) {
StringBuilder stringBuilder = new StringBuilder();
for(String string: strings) {
if(!string.isEmpty()) {
stringBuilder.append(string);
stringBuilder.append(separator);
}
}
String mergedString = stringBuilder.toString();
return mergedString.substring(0, mergedString.length()-2);
}
private static List<Integer> getSquares(List<Integer> numbers) {
List<Integer> squaresList = new ArrayList<Integer>();
for(Integer number: numbers) {
Integer square = new Integer(number.intValue() * number.intValue());
if(!squaresList.contains(square)) {
squaresList.add(square);
}
}
return squaresList;
}
private static int getMax(List<Integer> numbers) {
int max = numbers.get(0);
for(int i = 1;i < numbers.size();i++) {
Integer number = numbers.get(i);
if(number.intValue() > max) {
max = number.intValue();
}
}
return max;
}
private static int getMin(List<Integer> numbers) {
int min = numbers.get(0);
for(int i= 1;i < numbers.size();i++) {
Integer number = numbers.get(i);
if(number.intValue() < min) {
min = number.intValue();
}
}
return min;
}
private static int getSum(List numbers) {
int sum = (int)(numbers.get(0));
for(int i = 1;i < numbers.size();i++) {
sum += (int)numbers.get(i);
}
return sum;
}
private static int getAverage(List<Integer> numbers) {
return getSum(numbers) / numbers.size();
}
}
परिणाम सत्यापित करें
का उपयोग कर वर्ग संकलित करें javac संकलक निम्नानुसार है -
C:\JAVA>javac Java8Tester.java
अब निम्नानुसार Java8Tester चलाएं -
C:\JAVA>java Java8Tester
यह निम्नलिखित परिणाम का उत्पादन करना चाहिए -
Using Java 7:
List: [abc, , bc, efg, abcd, , jkl]
Empty Strings: 2
Strings of length 3: 3
Filtered List: [abc, bc, efg, abcd, jkl]
Merged String: abc, bc, efg, abcd, jkl
Squares List: [9, 4, 49, 25]
List: [1, 2, 13, 4, 15, 6, 17, 8, 19]
Highest number in List : 19
Lowest number in List : 1
Sum of all numbers : 85
Average of all numbers : 9
Random Numbers:
-1279735475
903418352
-1133928044
-1571118911
628530462
18407523
-881538250
-718932165
270259229
421676854
Using Java 8:
List: [abc, , bc, efg, abcd, , jkl]
Empty Strings: 2
Strings of length 3: 3
Filtered List: [abc, bc, efg, abcd, jkl]
Merged String: abc, bc, efg, abcd, jkl
Squares List: [9, 4, 49, 25]
List: [1, 2, 13, 4, 15, 6, 17, 8, 19]
Highest number in List : 19
Lowest number in List : 1
Sum of all numbers : 85
Average of all numbers : 9.444444444444445
Random Numbers:
-1009474951
-551240647
-2484714
181614550
933444268
1227850416
1579250773
1627454872
1683033687
1798939493
Empty Strings: 2