Java Platform, Standard Edition 8 (w skrócie Java SE 8 czy po prostu Java 8) jest już powszechnie dostępne. Wiele się zmieniło i pewnie nie tylko ja chciałbym wiedzieć, na ile Java 8 jest warta poznania, po tym, kiedy zarzucono ją na rzecz innych języków programowania - Clojure, Scala, Groovy. Ty też chciał(a)byś wiedzieć, co się zmieniło w najnowszej wersji Java 8? Najlepiej zacząć prosto u źródła - JDK 8 Release Notes lub What's New in JDK 8. Jest tego sporo do czytania, co może świadczyć o niemałych zmianach i dłużej nauce. Taka nasza informatyczna dola...
Pierwsza ciekawostka dla mnie to nazewnictwo - Java SE 8 vs JDK 8. Nie było to tak oczywiste, bo Java SE 8 to specyfikacja, a JDK 8 jej implementacją od Oracle. Jakoś wcześniej mi to umykało. Tak przynajmniej napisano w dokumentacji.
Mówi się, że najlepszym sposobem na naukę nowego języka jest po prostu korzystać z niego. Dotyczy to języka mówionego i dobrze sprawdza się również z językiem programowania. W ten sposób właśnie zamierzam poznać Java 8. Na swoim blogu proponuję pracę z IntelliJ IDEA 13. Właśnie kilka dni temu wyszła wersja 13.1.1 i wystarczy pobrać bezpłatną wersję Community Edition.
Przy założeniu, że Java 8 została zainstalowana, w IDEA wybierasz Create New Project, a później Java, wciskasz Next, aż pojawi się panel, w którym po raz pierwszy wybieramy Java 8 jako środowisko pracy.
Po stworzeniu projektu, upewnij się, że Project language level ustawiony jest na 8.0 - Lambdas, type annotations, etc.
Mając projekt można zacząć rozpoznawać Java 8 API. Od czego zaczniemy? Może java.util.stream?! A nie inaczej, skoro jest to (wraz z lambdami) jedna z ważniejszych zmian w tej wersji języka.
"Classes in the new java.util.stream package provide a Stream API to support functional-style operations on streams of elements. The Stream API is integrated into the Collections API, which enables bulk operations on collections, such as sequential or parallel map-reduce transformations."
Zaczniemy właśnie od Stream API, bo rozpoznając ten kawałek Java 8 nie sposób nie dotknąć innych zmian jak chociażby wspomniane lambdy.
Na tej stronie można doświadczyć pierwszego spotkania ze zmianami w Java 8:
Integer[] intArray = {1, 2, 3, 4, 5, 6, 7, 8 };
List listOfIntegers =
new ArrayList<>(Arrays.asList(intArray));
System.out.println("Sum of integers: " +
listOfIntegers
.stream()
.reduce(Integer::sum).get());
Zacznijmy od tego kawałka.
Na początku rzuciło mi się, dlaczego new ArrayList<>(Arrays.asList(intArray)) zamiast po prostu Arrays.asList(intArray)? Pewnie jakaś ukryta wiedza magiczna.
Dla adeptów Java 8 nową metodą w java.util.List<t>, a dokładniej java.util.Collection jest default Stream stream(), który (za javadoc):
"Returns a sequential Stream with this collection as its source."
Po pierwsze, co oznacza default przy sygnaturze?
Po drugie, czym jest Stream?
Po trzecie, skoro stream() zwraca “a sequential Stream”, to czy istnieje inny rodzaj Stream, np. non-sequential?
Wierzę i wspieram możliwymi sposobami polskie firmy informatyczne. Szczególnie leżą mi na sercu firmy, które nie próbują być aktywne, ale faktycznie takimi są i mają wpływ na lokalne społeczności informatyczne.
Tym wpisem zaczynam pewien cykl promocji firm, z którymi warto zamienić słowo, kiedy poszukuje się pracy (albo nawet wcześniej, aby dowiedzieć się, jak wiele się traci siedząc, gdzie się siedzi obecnie). Taką firmą jest Polidea i kiedy +Jarek Potiuk zapytał mnie o możliwe znajomości w branży na stanowisko DevOp/SysOp, postanowiłem wesprzeć jego poszukiwania.
Panie i Panowie...oto ono...miejsce dla najlepszych w temacie zarządzania infrastrukturą. Zachęcam do kontaktu. Ja jestem za słaby, więc można mnie śmiało wykreślić z listy potencjalnych kandydatów na to stanowisko. Powodzenia życzę!
W kanonie spotkań jest rozwiązywanie zadań z zestawu S-99: Ninety-Nine Scala Problems - dwa, czasami nawet trzy zadania. Czasami idzie nam sprawniej, a czasami trochę się przedłuża. Zawsze mam z tym problem, aby przydzielić temu czas, bo nawet stali bywalcy, którzy niejednokrotnie już rozwiązywali te zadania - ukłon w stronę +Rafała Krzewskiego czy +Grzegorza Kubiaka czy +Piotra Trzpila - mają z tym niemały problem. I to jest dobre! Każdy może dołączyć do nas, do bywalców i tych rzadziej uczestniczących w spotkaniach w dowolnym momencie i liczyć, że będzie mógł odnaleźć się w towarzystwie. Klimat spotkań zachęca do dyskusji i aktywniejszego udziału (nieprawdaż +Dominiko Biel, nieprawdaż +Dominiku Wiernicki?)
Firma Javeo zapewnia miejsce z dostępem do sieci oraz napoje i pizze (w tym wegetariańską). W ten sposób mamy zagwarantowane 20 minut na przerwę, w której dyskutujemy o rzeczach ważnych i mniej ważnych. Zwykle przeciąga się to do 30, a nawet 40 minut. Wcale nie traci na tym wiedza scalowa, bo jest to moment, w którym wciąż dyskutujemy o sprawach scalowych, w mniej formalnej atmosferze - poza czasem antenowym, tj. poza Google Hangouts on Air.
Ogromne podziękowania należą się +Grzegorzowi Kubiakowi, Magdzie i szefostwu Javeo za udostępnienie nam miejsca i zapewnienie wyżywienia podczas naszych scalań.
Na ostatnim spotkaniu, zaraz po przerwie żywieniowej, "dorobiliśmy" się nowej pozycji w ramówce spotkań - 15-minutówce o szkielecie aplikacyjnym Akka. Tym razem +Andrzej Goławski wprowadził nas w temat jak się zabrać za Akkę. I to jemu również należą się brawa za pomysł! To kolejne wystąpienie Andrzeja podczas spotkań scalowych i widać, że za niedługo będzie z uśmiechem wspominał pierwsze kroki w wystąpieniach publicznych. Idzie mu zupełnie dobrze i tylko czekać, aż się weźmie za dłuższe i bardziej zaawansowane tematy podczas swoich prezentacji. Uważam go za ciekawą personę na scenie społecznościowej w Warszawie (hint: warto zaprosić go na jakąś prezentację już teraz zanim...nie dopchasz się do niego!).
Po Acce, zaproponowałem kolejne potyczki scalowe ze Scala API. Na tapetę wzięliśmy napisanie od zera metod Seq.takeWhile oraz Seq.grouped. Co ciekawe, przy ich pisaniu można było nauczyć się innych. Duże brawa dla +Grzegorza Kossakowskiego za kompetentną pomoc przy ich pisaniu. Udział Grzegorza jest zawsze witany z dużym aplauzem, bo nietrudno zauważyć jego nieprzeciętną wiedzę w obszarze zachowania kompilatora Scali. Bardzo podoba mi się taki sposób poznawania samego języka oraz biblioteki standardowej Scala API i to z pewnością będzie stałym elementem spotkań. Zawsze weźmiemy sobie jedną-dwie metody na tapetę i wspólnymi siłami spróbujemy je napisać od zera.
Tak zeszło nam do końca spotkania, które zakończyło się wyjątkowo o 20:30. Późno, ale szukać ze świecą tego, komu mogło się nudzić (przynajmniej ja takowych nie zauważyłem, a że specjalnie nie szukałem, więc...nieważne).
Zachęcam do udziału w spotkaniu w biurze Javeo lub zdalnie. Proszę o kontakt osoby zainteresowane udziałem zdalnym, którzy jednocześnie chcieliby mieć możliwość zabrania głosu podczas spotkania. Google Hangouts on Air pozwala na to, jedynie specjalnie zaproszonym osobom. Dziękuję dotychczasowym zdalnym. Pracuję nad większym Waszym udziałem, ale bez Twojej pomocy będzie mi znacznie trudniej.
Prace nad odpaleniem zdalnej prezentacji o sbt (narzędziu do zarządzania budowaniem projektu z użyciem języka Scala) trwały od 18 stycznia, kilka dni po tym, kiedy +Silesia Scala oznajmiła na twitterze, że przyjmuje zgłoszenia tematów związanych ze Scalą.
Od kilku miesięcy siedzę przy sbt i szukam różnych miejsc sprawdzenia się w boju z moją znajomością tematu. Chciałbym móc pochwalić się wieloma projektami, ale poza jednym produkcyjnym projektem w mojej firmie z użyciem sbt, moim głównym źródłem wiedzy są pytania na StackOverflow pod szyldem sbt. Właśnie wczoraj otrzymałem odznakę sbt za uzyskanie 100 punktów za 20 odpowiedzi, co jest dla mnie istotnym osobistym osiągnięciem.
Moją aktywność na SO traktuję jako swego rodzaju projekt, w którym dotykam problemów, z którymi mógłbym nawet nie mieć styczności podczas swoich (projektów). Zrozumienie opisów przedstawionych problemów jest dla mnie samo w sobie wyzwaniem, a co tu mówić o znajomości sbt na poziomie umożliwiającym podanie rozwiązania. Doszło już do tego, że nierzadko zaglądam do kodów źródłowych narzędzia, aby zrozumieć jego zachowanie, a że znajomość Scali wciąż u mnie na poziomie podstawowym, więc nie jest lekko.
Wszystko to sprawiło, że pomyślałem, że mógłbym spróbować swoich sił w roli prelegenta na +Silesia Scala i przedstawić (swoje rozumienie) sbt. Chwyciło!
I tak się zaczęło, a wczoraj zrealizowało.
Zawsze byłem i jeszcze długo będę orędownikiem takich aktywności zdobywania wiedzy, a że nigdy tego za mało, przypomnę się ponownie. Zachęcam do takich inicjatyw każdego, komu leży na sercu dzielenie się wiedzą pro publico bono (z oczywistym zyskiem podniesienia swojego rozpoznania danego tematu). Warto potraktować publiczne wystąpienie jako inny rodzaj projektu, w którym wiedzy z pewnością nigdy za wiele. Zawsze znajdzie się pytanie, na które odpowiedź będzie przyczynkiem do przekroczenia bariery swojej znajomości tematu. I to jest dobre!
Osoby, które mają ze mną bliższy kontakt doświadczyły niejednokrotnie realizacji mojego motto, które brzmi:
"Każdy ma wystarczająco dużo wiedzy, aby móc się nią podzielić z innymi"
Innymi słowy, nie trzeba być ekspertem w wybranym obszarze, aby móc podzielić się już pozyskaną wiedzą.
Niestety, doświadczyłem niejednokrotnie na własnej skórze, że oczekiwanie jest zwykle, że prelegent wie więcej niż wszyscy słuchacze lub co najmniej od większości na sali. To niestety ma tę wadę, że nie zachęca do prezentacji swojej wiedzy, którą zwykle (zawsze?) uważamy za niewystarczającą do publicznej ekspozycji. Z drugiej strony słabe przygotowanie tematyczne może spotkać się z dezaprobatą i brakiem zainteresowania kolejnymi prezentacjami tej osoby w przyszłości, do której przylgnie nalepka "nauczyć się od niej raczej niemożliwe". Trzeba znaleźć balans między doskonałością a przeciętnością. Przykre to o tyle, że tworzy się impas i trzeba dużej odwagi i samooceny, aby w końcu zechcieć wystąpić publicznie. Nie wspominając, że Ci, którzy mają wiedzę, zwykle nie mają czasu lub ochoty lub po prostu nie widzą sensu dla takich praktyk. I to też jest problemem, bo nie ma wielu do wzięcia na siebie brzemienia krzewienia wiedzy i pracy u podstaw. "Wszystkich nie zadowolisz" jak mawiają.
Dla mnie wczorajsze spotkanie było niezwykłym sprawdzianem swojej wiedzy z sbt. Starałem się zachować umiar w moich ochach i echach odnośnie sbt oraz zachować ogólny spokój w sposobie przedstawiania tematu. Mam tendencję do przedobrzania i zbytniego entuzjazmu w podejmowaniu się wyzwań podczas prezentacji, głównie w postaci podejmowania się rozwiązywania problemów, z którymi nie miałem do czynienia wcześniej podczas publicznych wystąpień, co ma tę wadę, że nierzadko prowadzi do wpadek, które źle poprowadzone kończą się niższymi ocenami uczestników. Trzeba być ostrożnym. Wpadłem bodaj trzykrotnie, aczkolwiek odpuściłem wyłącznie, aby nie zajmować uczestników rozwiązaniami, których wartość merytoryczna była znikoma, a czas poświęcony ogromny. Lubię stąpać po obrzeżach swojej wiedzy, ale zbytnia frywolność związana z czasem "antenowym" jest niewskazana.
Co uważam za największe osiągnięcie wirtualnej prezentacji sbt, to panowanie nad czasem poszczególnych kawałków prezentacji, między którymi pozwoliłem sobie na angażowanie publiczności do zadawania pytań, czy po prostu zajmowania stanowiska. Było ciekawie i pytania publiczności pozwoliły mi uzupełnić prezentację sbt o elementy, których nie miałem w planach i nie uważałem za istotne.
Pełne nagranie spotkania znajduje się na kanale YouTube grupy Silesia Scala. Zachęcam do obejrzenia i przesłaniu swoich uwag, które wykorzystam do uzupełnienia swoich braków prezentacyjnych oraz w sbt. Bardzo, bardzo proszę o przesłanie uwag, bo moje ego nie pozwala mi dostrzec wad, nad którymi powinienem popracować. Bez Twojej pomocy będzie mi ciężko, jeśli w ogóle możliwe.
Dziękuję grupie +Silesia Scala, a w szczególności panom +Henryk Konsek, Pawłowi Sołtyskowi za organizację spotkania i umożliwienie poprowadzenia sesji na temat sbt. Dodatkowe podziękowania należą się Andrzejowi za pytania dotyczące sbt 0.13.0 oraz Marcinowi Kubale za zdalny udział w spotkaniu i zadawanie pytań. Dziękuję pozostałym uczestnikom za wytrwanie do końca, co pozwala mi sądzić, że prezentacja mogła być wartościowa chociaż dla części. Dziękuję!
Więcej informacji, w tym zdjęcia ze spotkania, znajdują się na stronie spotkania na meetupie grupy Silesia Scala User Group. Wierzę, że to nie jest moje ostatnie wystąpienie na deskach SSUGa i chętnie wystąpię u innych grup scalowych i javowych w Polsce.
W nadchodzący poniedziałek, 3 marca 2014 od godziny 18:00 na Wydziale Matematyki, Informatyki i Mechaniki Uniwersytetu Warszawskiego (MIMUW) w sali 5440 odbędzie się spotkanie warszawskiego grupy scalowej, w którym gwiazdą wieczoru będzie pracownik Typesafe (firmy stojącej za językiem Scala) - Jamie Allen, który opowie o szkielecie aplikacyjnym Akka.
Udział w spotkaniu na chwilę obecną potwierdziło 28 uczestników oraz trzech sponsorów, którzy zadbają o oprawę spotkania - strawę, napoje oraz książki o Acce. Kiedy tylko pomyślisz o Scali w Polsce, powinno być już dużo łatwiej zdecydować, do których firm należy skierować swoje kroki w poszukiwaniu interesujących projektów z tym językiem.