{"id":10054,"date":"2023-12-12T11:34:48","date_gmt":"2023-12-12T14:34:48","guid":{"rendered":"https:\/\/elemarjr.com\/clube-de-estudos\/?post_type=artigos&#038;p=10054"},"modified":"2023-12-26T09:52:35","modified_gmt":"2023-12-26T12:52:35","slug":"lei-de-moore-nao-vale-mais-a-alternativa-e-a-programacao-concorrente","status":"publish","type":"artigos","link":"https:\/\/elemarjr.com\/clube-de-estudos\/artigos\/lei-de-moore-nao-vale-mais-a-alternativa-e-a-programacao-concorrente\/","title":{"rendered":"Lei de Moore N\u00e3o Vale Mais: A Alternativa \u00e9 a Programa\u00e7\u00e3o Concorrente"},"content":{"rendered":"\n<p>A Lei de Moore tem sido um farol para o avan\u00e7o tecnol\u00f3gico por d\u00e9cadas. Proposta por Gordon Moore em 1965, ela sugeria que a capacidade de processamento dos computadores dobraria a cada 18 meses. No entanto, chegamos a um ponto em que os ganhos de desempenho n\u00e3o est\u00e3o mais ligados apenas \u00e0 pot\u00eancia do hardware. Os processadores de hoje, com m\u00faltiplos n\u00facleos, exigem uma nova abordagem: a programa\u00e7\u00e3o concorrente.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">A Mudan\u00e7a no Paradigma de Processamento<\/h2>\n\n\n\n<p>A era da Lei de Moore trouxe otimismo e avan\u00e7o. Cada novo modelo de processador significava um salto not\u00e1vel na performance. Mas os tempos mudaram. Agora, processadores multicore s\u00e3o a norma e embora possuam a capacidade de realizar tarefas simult\u00e2neas, a velocidade de processamento individual estagnou. Isso demanda dos desenvolvedores um novo conjunto de habilidades.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Programa\u00e7\u00e3o Concorrente como a Nova Fronteira<\/h2>\n\n\n\n<p>Desbloquear o potencial desses processadores multicore depende de uma abordagem de programa\u00e7\u00e3o concorrente eficaz. Aqui reside o verdadeiro avan\u00e7o de performance na era p\u00f3s-Lei de Moore. Contudo, adotar a programa\u00e7\u00e3o concorrente \u00e9 complexo, envolve compreender a fundo temas como sincroniza\u00e7\u00e3o e gerenciamento de estados compartilhados, aspectos cr\u00edticos para evitar condi\u00e7\u00f5es de corrida.<\/p>\n\n\n\n<p>Para ilustrar a aplica\u00e7\u00e3o pr\u00e1tica e os benef\u00edcios da programa\u00e7\u00e3o concorrente, considere um servi\u00e7o de processamento de imagens que opera em um grande volume de dados. Ao implementar a programa\u00e7\u00e3o concorrente, esse servi\u00e7o pode distribuir o processamento entre diferentes n\u00facleos, possibilitando um aumento significativo no n\u00famero de opera\u00e7\u00f5es executadas simultaneamente e, consequentemente, uma redu\u00e7\u00e3o no tempo de resposta do servi\u00e7o.<\/p>\n\n\n\n<p>Vamos demonstrar um simples exemplo de programa\u00e7\u00e3o concorrente com threads em C#:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" style=\"font-size:.875rem;line-height:1.25rem\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#2e3440ff\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" data-code=\"using System;\nusing System.Threading;\n\npublic class Example\n{\n    public static void Main()\n    {\n        Thread thread = new Thread(new ThreadStart(ProcessImages));\n        thread.Start(); \/\/ Inicia a execu\u00e7\u00e3o concorrente\n    }\n\n    public static void ProcessImages()\n    {\n        \/\/ C\u00f3digo para processamento de imagens\n        Console.WriteLine(&quot;Processing images concurrently...&quot;);\n    }\n}\" style=\"color:#d8dee9ff;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki nord\" style=\"background-color: #2e3440ff\"><code><span class=\"line\"><span style=\"color: #81A1C1\">using<\/span><span style=\"color: #D8DEE9FF\"> System<\/span><span style=\"color: #81A1C1\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #81A1C1\">using<\/span><span style=\"color: #D8DEE9FF\"> System.Threading<\/span><span style=\"color: #81A1C1\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #81A1C1\">public<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">class<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #8FBCBB\">Example<\/span><\/span>\n<span class=\"line\"><span style=\"color: #ECEFF4\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #81A1C1\">public<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">static<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">void<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #88C0D0\">Main<\/span><span style=\"color: #ECEFF4\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        Thread thread <\/span><span style=\"color: #81A1C1\">=<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">new<\/span><span style=\"color: #D8DEE9FF\"> Thread<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #81A1C1\">new<\/span><span style=\"color: #D8DEE9FF\"> ThreadStart<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #D8DEE9\">ProcessImages<\/span><span style=\"color: #ECEFF4\">))<\/span><span style=\"color: #81A1C1\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        <\/span><span style=\"color: #D8DEE9\">thread<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">Start<\/span><span style=\"color: #ECEFF4\">()<\/span><span style=\"color: #81A1C1\">;<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #616E88\">\/\/ Inicia a execu\u00e7\u00e3o concorrente<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">}<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #81A1C1\">public<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">static<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">void<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #88C0D0\">ProcessImages<\/span><span style=\"color: #ECEFF4\">()<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color: #ECEFF4\">        <\/span><span style=\"color: #616E88\">\/\/ C\u00f3digo para processamento de imagens<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        <\/span><span style=\"color: #D8DEE9\">Console<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">WriteLine<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #ECEFF4\">&quot;<\/span><span style=\"color: #A3BE8C\">Processing images concurrently...<\/span><span style=\"color: #ECEFF4\">&quot;<\/span><span style=\"color: #ECEFF4\">)<\/span><span style=\"color: #81A1C1\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">}<\/span><\/span>\n<span class=\"line\"><span style=\"color: #ECEFF4\">}<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>Este \u00e9 um exemplo b\u00e1sico, mas evolu\u00edmos para a cria\u00e7\u00e3o de tarefas paralelas com uso de <code>async<\/code> e <code>await<\/code>, explorando bibliotecas como <em>Task Parallel Library<\/em> (TPL) e padr\u00f5es como <code>Parallel.For<\/code> e <code>Parallel.ForEach<\/code>.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Conclus\u00e3o<\/h2>\n\n\n\n<p>O panorama atual exige que desenvolvedores se ajustem ao paradigma da programa\u00e7\u00e3o concorrente, explorando novos modelos de computa\u00e7\u00e3o paralela para otimizar o uso de hardware moderno. Para quem deseja aprofundar seus conhecimentos na pr\u00e1tica, recomendo explorar recursos como o livro &#8220;Concurrency in C# Cookbook&#8221; de Stephen Cleary, ou cursos online focados em programa\u00e7\u00e3o concorrente e paralela. Estas discuss\u00f5es, m\u00e9todos e pr\u00e1ticas s\u00e3o exploradas em meus grupos de estudos e mentorias, preparando os desenvolvedores para as exig\u00eancias do mercado tecnol\u00f3gico atual e suas devidas nuances de implementa\u00e7\u00e3o.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">TL;DR<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li>A Lei de Moore n\u00e3o \u00e9 mais uma realidade, n\u00e3o podemos contar com o aumento de capacidade de processamento apenas pelo hardware.<\/li>\n\n\n\n<li>A programa\u00e7\u00e3o concorrente \u00e9 essencial para otimizar o desempenho de sistemas que utilizam processadores multicore.<\/li>\n\n\n\n<li>\u00c9 fundamental que os desenvolvedores busquem aprimorar suas habilidades em programa\u00e7\u00e3o concorrente, inclusive atrav\u00e9s de recursos externos e pr\u00e1ticas atualizadas.<\/li>\n<\/ol>\n","protected":false},"featured_media":10031,"parent":0,"template":"","cursos":[5],"class_list":["post-10054","artigos","type-artigos","status-publish","has-post-thumbnail","hentry","cursos-algortimos"],"acf":[],"_links":{"self":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/artigos\/10054","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/artigos"}],"about":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/types\/artigos"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/media\/10031"}],"wp:attachment":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/media?parent=10054"}],"wp:term":[{"taxonomy":"cursos","embeddable":true,"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/cursos?post=10054"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}