{"id":292,"date":"2019-07-23T15:45:05","date_gmt":"2019-07-23T15:45:05","guid":{"rendered":"https:\/\/micheladrianomedeiros.com.br\/blog\/?p=292"},"modified":"2019-07-23T15:45:08","modified_gmt":"2019-07-23T15:45:08","slug":"recursos-avancados-do-java-1","status":"publish","type":"post","link":"https:\/\/micheladrianomedeiros.com.br\/blog\/recursos-avancados-do-java-1\/","title":{"rendered":"Recursos Avan\u00e7ados do Java #1"},"content":{"rendered":"\n<p class=\"has-text-color has-vivid-cyan-blue-color wp-block-paragraph\"><strong>A Biblioteca Stream<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Streams fornece uma vis\u00e3o dos\ndados que permite voc\u00ea especificar altos conceitos computacionais mais do que com\ncole\u00e7\u00f5es. Com uma Stream, voc\u00ea especifica o que quer fazer, n\u00e3o como fazer.\nVoc\u00ea agenda opera\u00e7\u00f5es para implementa\u00e7\u00f5es. Por exemplo, suponhamos que voc\u00ea\nquer a m\u00e9dia de uma certa propriedade. Voc\u00ea especifica a fonte de dados e a\npropriedade, e a biblioteca Stream pode otimizar a computa\u00e7\u00e3o, por exemplo,\nutilizar m\u00faltiplas threads para computar somas, contas e combina\u00e7\u00f5es de\nresultados. <\/p>\n\n\n\n<p class=\"has-text-color has-vivid-cyan-blue-color wp-block-paragraph\"><strong>Interagindo com Opera\u00e7\u00f5es da\nStream<\/strong><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Quando voc\u00ea processa uma cole\u00e7\u00e3o,\nvoc\u00ea costuma ler cada elemento da cole\u00e7\u00e3o e trabalhar um por um. Por exemplo,\nsuponhamos que n\u00f3s queremos contar todas as palavras de um livro. Primeiro,\ntemos que colocarmos ele dentro de uma lista.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>import java.nio.*;\nimport java.nio.charset.*;\nimport java.nio.file.*;\nimport java.util.*;\n\npublic class LerArquivo{\n\tpublic static void main(String[] args){\n\t\ttry{\n\t\t\t\/\/ vai ler o arquivo\n\t\t\tString contents = new String(Files.readAllBytes(\n\t\t\tPaths.get(\"alice.txt\")), StandardCharsets.UTF_8); \n\t\t\t\/\/ separa as palavras\n\t\t\tList&lt;String> words = Arrays.asList(contents.split(\"\\\\PL+\"));\n\t\t\tSystem.out.println(\"words \" +words.size());\n\t\t}catch(Exception e){\n\t\t\tSystem.out.println(\"ERRO \"+e.getMessage());\n\t\t}\n\t}\n}\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">O arquivo alice.txt voc\u00ea pode criar\nqualquer texto dentro de um bloco de notas. <\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Agora vamos fazer uma intera\u00e7\u00e3o:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>long count = 0;\n\tfor(String w : words){\n\t\tif(w.length() > 12) count ++;\n\t}<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">Fazendo a mesma intera\u00e7\u00e3o utilizando\na Streams.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>long count = words.stream()\n\t.filter(w -> w.length() > 12)\n\t.count();\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">A vers\u00e3o Stream \u00e9 mais f\u00e1cil de\nler do que a loop, porque voc\u00ea n\u00e3o precisa scanear o c\u00f3digo para filtrar e\ncontar. Os nomes dos m\u00e9todos dizem o que pretendem fazer. Al\u00e9m disso, o While enquanto\nn\u00e3o terminar os recursos do sistema est\u00e3o dedicados a ele, a Stream age da\nmesma maneira, s\u00f3 que temos a op\u00e7\u00e3o de agendar a opera\u00e7\u00e3o.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Simplesmente modificando a Stream\npara parallelStream para fazer o filtro e a contagem em paralelo.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>long count = words. parallelStream()\n\t.filter(w -> w.length() > 12)\n\t.count();\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">A Stream segue o princ\u00edpio do \u201cO\nque\u201d e n\u00e3o do \u201cComo\u201d. No exemplo, descrevemos o que precisa ser feito: pegue as\npalavras e conte. N\u00e3o precisamos especificar a ordem, ou uma thread para que\nisto fosse feito. Diferente do loop que no come\u00e7o da tarefa especificamos exatamente\ncomo o computador deve trabalhar, e com isto perdemos qualquer chance de otimiza\u00e7\u00e3o.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">A Stream parece superficialmente\ncom uma cole\u00e7\u00e3o, permite voc\u00ea transformar e capturar os dados. Mas h\u00e1\ndiferen\u00e7as significativas:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Uma Stream n\u00e3o armazena os elementos.\nEles podem ser armazenados em outro lugar ou serem gerados por demanda.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Opera\u00e7\u00f5es da Stream n\u00e3o mudam\no c\u00f3digo fonte. Por exemplo, o m\u00e9todo filter n\u00e3o remove os elementos para criar\numa nova Stream, mas os campos onde eles estavam ocupando, n\u00e3o existiram mais. <\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Opera\u00e7\u00f5es da Stream s\u00e3o lazy\nquando poss\u00edvel. Isto significa que eles n\u00e3o s\u00e3o executados at\u00e9 que precisem\nser. Por exemplo, se voc\u00ea pedir as primeiras palavras de uma lista ao inv\u00e9s de\ntodas, o m\u00e9todo filter ir\u00e1 parar de filtrar depois da quinta ocorr\u00eancia. Com consequ\u00eancia,\nvoc\u00ea pode ter Streams infinitas. <\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Vamos ver um outro exemplo. Os\nm\u00e9todos stream e parallelStream produz intera\u00e7\u00e3o com as palavras da lista. O\nm\u00e9todo filter retorna outro fluxo que cont\u00e9m apenas palavras maiores que doze. O\nm\u00e9todo count reduz o fluxo do resultado.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Este fluxo \u00e9 t\u00edpico quando se\ntrabalha com streams (fluxos). Voc\u00ea configura tr\u00eas est\u00e1gios de trabalho.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Cria uma stream.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Espec\u00edfica opera\u00e7\u00f5es\nintermediarias para transformar o fluxo inicial em outros, possibilitando\nm\u00faltiplos passos.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Aplica uma opera\u00e7\u00e3o final para\nproduzir o resultado. Esta opera\u00e7\u00e3o for\u00e7a a execu\u00e7\u00e3o das opera\u00e7\u00f5es lazy que as\nprecedem. Depois, o fluxo n\u00e3o pode ser mais utilizado.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">No nosso c\u00f3digo o fluxo \u00e9 criado\ncom o m\u00e9todo stream ou parallelStream. O m\u00e9todo filter faz a transforma\u00e7\u00e3o e o\ncount realiza a opera\u00e7\u00e3o final.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Visite a documenta\u00e7\u00e3o para ver\nos m\u00e9todos mencionados.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/java\/util\/stream\/Stream.html\">https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/java\/util\/stream\/Stream.html<\/a><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>import java.nio.*;\nimport java.nio.charset.*;\nimport java.nio.file.*;\nimport java.util.*;\n\npublic class LerArquivo{\n\tpublic static void main(String[] args){\n\t\ttry{\n\t\t\t\/\/ vai ler o arquivo\n\t\t\tString contents = new String(Files.readAllBytes(\n\t\t\tPaths.get(\"alice.txt\")), StandardCharsets.UTF_8); \n\t\t\t\/\/ separa as palavras\n\t\t\tList&lt;String> words = Arrays.asList(contents.split(\"\\\\PL+\"));\n\t\t\tSystem.out.println(\"words \" +words.size());\n\t\t\t\n\t\t\tlong count = words.parallelStream()\n\t\t\t.filter(w -> w.length() > 12)\n\t\t\t.count();\n\t\t\t\n\t\t\t\/*\n\t\t\tlong count = words.stream()\n\t\t\t.filter(w -> w.length() > 12)\n\t\t\t.count();\n\t\t\t*\/\n\t\t\t\/*long count = 0;\n\t\t\tfor(String w : words){\n\t\t\t\tif(w.length() > 12) count ++;\n\t\t\t}*\/\n\t\t\t\n\t\t\tSystem.out.println(\"count \" +count);\n\t\t\t\n\t\t}catch(Exception e){\n\t\t\tSystem.out.println(\"ERRO \"+e.getMessage());\n\t\t}\n\t}\n}\n<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u2764\ufe0f&nbsp;Curso Java Para Iniciantes&nbsp;&nbsp;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">&gt;&gt;&gt;&nbsp;<a href=\"http:\/\/bit.ly\/java-swing\" target=\"_blank\" rel=\"noreferrer noopener\">http:\/\/bit.ly\/java-swing<\/a>&nbsp;&nbsp;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\ud83d\udc4d&nbsp;Curso de Desenvolvimento Web Completo&nbsp;&nbsp;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">&gt;&gt;&gt;&nbsp;<a href=\"http:\/\/bit.ly\/2FnB5Sp\" target=\"_blank\" rel=\"noreferrer noopener\">http:\/\/bit.ly\/2FnB5Sp<\/a>&nbsp;&nbsp;&nbsp;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">#java&nbsp;&nbsp;<\/p>\n\n\n","protected":false},"excerpt":{"rendered":"<p>A Biblioteca Stream Streams fornece uma vis\u00e3o dos dados que permite voc\u00ea especificar altos conceitos computacionais mais do que com cole\u00e7\u00f5es. Com uma Stream, voc\u00ea especifica o que quer fazer, n\u00e3o como fazer. Voc\u00ea agenda opera\u00e7\u00f5es para implementa\u00e7\u00f5es. Por exemplo, suponhamos que voc\u00ea quer a m\u00e9dia de uma certa propriedade. Voc\u00ea especifica a fonte de [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":293,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[5,60],"class_list":["post-292","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-java","tag-java","tag-javaavancado"],"_links":{"self":[{"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/posts\/292","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/comments?post=292"}],"version-history":[{"count":2,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/posts\/292\/revisions"}],"predecessor-version":[{"id":295,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/posts\/292\/revisions\/295"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/media\/293"}],"wp:attachment":[{"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/media?parent=292"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/categories?post=292"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/micheladrianomedeiros.com.br\/blog\/wp-json\/wp\/v2\/tags?post=292"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}