Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
J
java_dzienna_15_09
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Patryk Czarnik
java_dzienna_15_09
Commits
30c3d84a
Commit
30c3d84a
authored
Sep 15, 2022
by
Patryk Czarnik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
proste filter i map
parent
50858cc8
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
90 additions
and
0 deletions
+90
-0
FilterMap.java
...ementyJavy/src/main/java/emps/strumieniowo/FilterMap.java
+27
-0
FilterMap_v2.java
...ntyJavy/src/main/java/emps/strumieniowo/FilterMap_v2.java
+28
-0
P1_WypiszZeStrumienia.java
...rc/main/java/emps/strumieniowo/P1_WypiszZeStrumienia.java
+19
-0
P2_WypiszBogatych.java
...vy/src/main/java/emps/strumieniowo/P2_WypiszBogatych.java
+16
-0
No files found.
PC22-ZaawansowaneElementyJavy/src/main/java/emps/strumieniowo/FilterMap.java
0 → 100644
View file @
30c3d84a
package
emps
.
strumieniowo
;
import
java.util.List
;
public
class
FilterMap
{
// Operacje na strumieniach zwykle łączy się w tzw. "pipeline", który:
// - zaczyna się od operacji tworzącej strumień
// - dalej posiada 0 lub więcej operacji pośrednich
// - na końcu ma operację terminującą.
// W tym przykładzie przeplatamy najbardziej standardowe operacje na strumieniach:
// filter - sprawdza czy element strumienia spełnia warunek i tylko jeśli tak, to przepuszcza do następnego etapu
// map - na podstawie elementu wejściowego zwraca jakiś wynik, który jest przekazywany do nast. etapu
public
static
void
main
(
String
[]
args
)
{
List
<
Employee
>
emps
=
ObslugaCSV
.
wczytaj
(
"emps.csv"
);
emps
.
stream
()
.
filter
(
emp
->
emp
.
getSalary
()
>=
10000
)
.
filter
(
emp
->
"Seattle"
.
equals
(
emp
.
getCity
()))
.
map
(
emp
->
emp
.
getFirstName
()
+
" "
+
emp
.
getLastName
())
.
filter
(
s
->
s
.
contains
(
"a"
))
.
map
(
s
->
s
.
toUpperCase
())
.
forEach
(
s
->
System
.
out
.
println
(
s
));
}
}
PC22-ZaawansowaneElementyJavy/src/main/java/emps/strumieniowo/FilterMap_v2.java
0 → 100644
View file @
30c3d84a
package
emps
.
strumieniowo
;
import
java.util.List
;
public
class
FilterMap_v2
{
// Operacje na strumieniach zwykle łączy się w tzw. "pipeline", który:
// - zaczyna się od operacji tworzącej strumień
// - dalej posiada 0 lub więcej operacji pośrednich
// - na końcu ma operację terminującą.
// W tym przykładzie przeplatamy najbardziej standardowe operacje na strumieniach:
// filter - sprawdza czy element strumienia spełnia warunek i tylko jeśli tak, to przepuszcza do następnego etapu
// map - na podstawie elementu wejściowego zwraca jakiś wynik, który jest przekazywany do nast. etapu
// W tej wersji tam, gdzie można, zamiast wyrażenia lambda -> zastosujemy method reference ::
public
static
void
main
(
String
[]
args
)
{
List
<
Employee
>
emps
=
ObslugaCSV
.
wczytaj
(
"emps.csv"
);
emps
.
stream
()
.
filter
(
emp
->
emp
.
getSalary
()
>=
10000
)
.
filter
(
emp
->
"Seattle"
.
equals
(
emp
.
getCity
()))
.
map
(
emp
->
emp
.
getFirstName
()
+
" "
+
emp
.
getLastName
())
.
filter
(
s
->
s
.
contains
(
"a"
))
.
map
(
String:
:
toUpperCase
)
.
forEach
(
System
.
out
::
println
);
}
}
PC22-ZaawansowaneElementyJavy/src/main/java/emps/strumieniowo/P1_WypiszZeStrumienia.java
0 → 100644
View file @
30c3d84a
package
emps
.
strumieniowo
;
import
java.util.List
;
// W tym przykładzie z listy pobierany jest obiekt "stream",
// a dopiero na nim wywołujemy forEach.
// Wydaje się to bez sensu, bo forEach działa dla listy (zob. wersję 0),
// ale stream() daje dostęp do wielu dodatkowych operacji, co zobaczymy w nast. przykładach.
public
class
P1_WypiszZeStrumienia
{
public
static
void
main
(
String
[]
args
)
{
List
<
Employee
>
emps
=
ObslugaCSV
.
wczytaj
(
"emps.csv"
);
emps
.
stream
().
forEach
(
emp
->
System
.
out
.
printf
(
"Pracownik %s %s (%s) zarabia %d\n"
,
emp
.
getFirstName
(),
emp
.
getLastName
(),
emp
.
getJobTitle
(),
emp
.
getSalary
()));
}
}
PC22-ZaawansowaneElementyJavy/src/main/java/emps/strumieniowo/P2_WypiszBogatych.java
0 → 100644
View file @
30c3d84a
package
emps
.
strumieniowo
;
import
java.util.List
;
public
class
P2_WypiszBogatych
{
public
static
void
main
(
String
[]
args
)
{
List
<
Employee
>
emps
=
ObslugaCSV
.
wczytaj
(
"emps.csv"
);
emps
.
stream
()
.
filter
(
emp
->
emp
.
getSalary
()
>=
10000
)
.
forEach
(
emp
->
System
.
out
.
printf
(
"Pracownik %s %s (%s) zarabia %d\n"
,
emp
.
getFirstName
(),
emp
.
getLastName
(),
emp
.
getJobTitle
(),
emp
.
getSalary
()));
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment