Try/Catch é PÉSSIMO (e como consertar)

Поделиться
HTML-код
  • Опубликовано: 23 янв 2025

Комментарии • 301

  • @fabioalvescorrea
    @fabioalvescorrea 5 месяцев назад +191

    Try..catch não é anti-pattern tampouco prejudica a legibilidade do código.
    Mascarar erros é anti-pattern. Usar try..catch em todo lugar é anti-pattern.
    E se vc pensar em usar try..catch prá escapar de loop, pede as contas agora mesmo.
    Erros tem que "borbulhar" na stack para serem tratados nos lugares certos. E try..catch é algo a ser usado com moderação, na hora certa, com o propósito certo. Assim como absolutamente tudo na programação, é mais uma ferramenta, não deve ser demonizado só porque tem mané que usa do jeito errado.
    Sem falar que as alternativas são piores. Por exemplo, o "tratamento" de erros do Golang é lindo quando você tem um programinha bem pequeno, com pouca coisa que pode dar errado.
    Mas quando a coisa toma corpo e vc tem que lidar com um enorme número de situações imprevisíveis, com tratamento de erros complexos, tratamentos diferentes para erros diferentes... aí meu amigo... você vai ter mais if(err) { ... } do que código de fato. E a legibilidade vai de vasco, fica péssimo de acompanhar até debugando. Experiência própria.

    • @diegocantelli
      @diegocantelli 5 месяцев назад +7

      Exato! O pessoal reinventa a roda demais.

    • @lucascardoso216
      @lucascardoso216 5 месяцев назад +4

      Comentário cirúrgico!

    • @andrelsjunior
      @andrelsjunior 5 месяцев назад +3

      O comentário que eu não escreveria, mas o comentário que eu precisava.

    • @_kevinpinzon
      @_kevinpinzon 4 месяца назад +2

      Exatamente... se tu vai colocar um try/catch sem que tua lógica tenha realmente uma ação pra isso, deixa o erro estourar na stack pq em algum ponto do código vai ser vital o tratamento

    • @jmarcos06
      @jmarcos06 4 месяца назад

      Trabalho numa stack em Go gigantesca e a pior parte dela é o Java legado. 🤐

  • @seunicolau
    @seunicolau 5 месяцев назад +113

    Então o problema não é try catch, por que ele tá por baixo dos panos pra poder retornar o error, mas sim não definir o tipo correto de retorno.

    • @gabriellmatias7203
      @gabriellmatias7203 5 месяцев назад +2

      Entao no caso eu colocaria que todas minhas funções podem retornar um tipo primário ou não, e também um erro caso haja um try catch dentro do método?

    • @seunicolau
      @seunicolau 5 месяцев назад +3

      @@gabriellmatias7203 exatamente. Por que assim voce consegue cascatear a tipagem, assim o compilador/transpilador vai identificar os tipos de retorno e avisar quando falta um tratamento próprio.
      Ex: Se tu declarar que tua função retorna Int | error, e na função que chama ela tu fizer algo como result + 1, o compilador vai reclamar que esse result pode ser do tipo Error, que não pode ser operado como Int.

  • @LucasOliveira-tq2uq
    @LucasOliveira-tq2uq 5 месяцев назад +87

    Pra quem quiser outras abordagens para evitar o uso de try catchs, recomendo pesquisarem e estudarem sobre Either Monads. É muito fácil de implementar e depois que você começa a de fato usar, não quer mais abandonar. Sugeri a utilização dele para a minha equipe e acabou se tornando um padrão em nossos projetos. Recomendo muito!

    • @Aircrackngarmagedom
      @Aircrackngarmagedom 5 месяцев назад +6

      Right!

    • @arodasiora
      @arodasiora 5 месяцев назад +1

      Obrigada!

    • @gabrizord
      @gabrizord 5 месяцев назад +2

      Optional em java é parecido

    • @rafaelschueng
      @rafaelschueng 5 месяцев назад +5

      Já já brota algum programador Haskell tentando explicar o que é uma Monada.

    • @vgerhard
      @vgerhard 5 месяцев назад +2

      Apesar de atualmente trabalhar com node, vou dar uma estudada em Either Monads....

  • @alexandreabto
    @alexandreabto 5 месяцев назад +17

    Toda provocação é válida quando o objetivo é evoluir. Mas sendo bem sincero, houve algus equívocos mais relacionados ao entendimento dos padrões da linguagem do que com o try/catch em si.
    Desde aninhamentos de try/catches sem um controle de escopo adequado, confusão com tipagem (python tem tipagem forte e dinâmica, inclusive) ou mesmo try/catch só mascarando erro ao invés de tratá-lo.
    Comparar alguns recursos de uma linguagem compilada com uma linguagem interpretada é como comparar laranjas e maçãs. Dá pra discutir trade-offs e usar isso pra melhorias na linguagem (tipo o type hint do python ou o typescript, meio que feitos para se aproximar de tipagem estática que você elogiou, por exemplo), mas usar uma amostra de código dificulta a discussão e não ajuda a entender o todo.
    Não subestime a capacidade de um dev cansado de fazer caquinha em Go também. kkkkkk

  • @TheFelipegustavo1000
    @TheFelipegustavo1000 5 месяцев назад +41

    O artigo muito taxativo e bom pra pegar dev junior que gosta de hype. Mais um artigo no Medium que busca polemizar. O autor apresenta exemplos baseados em TypeScript. Nesses tipos de linguagem, devido a liberdade da fazer como você quiser, cabe ao programador tomar os seus devidos cuidados. Esse artigo, assim como video, só leva em consideração o mundo da sua linguagem e esse é um detalhe muito importante. Tenta fazer uma requisição web no Java pra ver se ele não te obrigar a usar um try-catch ou um throws na assinatura do método caso o caller vá tratar a exceção. Tem linguagem que não tem pra onde correr. E isso bom na minha opinião. Deixa na mão de um cara iniciante sem supervisão a decisão de como tratar a exceção, logo logo você vai ver o cara fazendo uma requisição sem tratamento de erro ou try catch, ai na primeira coisinha pipoca tudo.

    • @AlexeiDimitri
      @AlexeiDimitri 4 месяца назад

      Não são todos os tipos de erro que Java obriga vc a tratar no tempo de desenvolvimento.
      Em geral, exceções explicitamente definidas tem o requisito de serem tratadas, mas existem erros que são são explícitos ou não tem a obrigatoriedade de se controlar (em geral, RuntimeExceptions e Errors)
      Aqui, pq try-catch é um padrão ruim para Typescript? Pq vc tá usando um pattern de linguagem sequencial numa linguagem projetada para ser assíncrona (olha como usam async/await toda hora), enquanto Java é puramente síncrona (tirando talvez quando vc estiver usando NIO ou non-blocking APIs)

  • @lobohacker
    @lobohacker 5 месяцев назад +77

    Discordo. Quem deve tratar os erros é o chamador de nível superior, e não a cadeia de chamadas.
    Os erros previsíveis que sejam validados via estrutura condicional e borbulhados para cima utilizando throw.
    Os erros não previsíveis basta deixar as Exception borbulharem naturalmente para cima e lá realizar o tratamento.

    • @victorbiasibetti
      @victorbiasibetti 5 месяцев назад +33

      sem falar que nao existe necessidade de try-catch dentro de try-catch
      isso é código de exemplo que nunca passaria numa PR real (se vc ver isso na codeboase do seu trabalho, comece a mandar curriculos imediatamente)

    • @lobohacker
      @lobohacker 5 месяцев назад +4

      @@victorbiasibetti exato

    • @fabiodosreisvianadasilva6850
      @fabiodosreisvianadasilva6850 5 месяцев назад +6

      Eu tbm penso assim, mas eu trabalho com java, e isso é padrão, fiquei pensando nesse caso de garantia de retorno de valor ai que o python não tem, pra mim isso deveria lançar a exception pra cima e parar o fluxo mesmo, sem o valor não da pra seguir na execução do fluxo.

    • @lobohacker
      @lobohacker 5 месяцев назад +6

      @@fabiodosreisvianadasilva6850 mas é justamente isso. Lançar a exception para cima usando o comando "raise" do python, equivalente ao throw. Não adianta a chamada ser obrigada a retornar um valor se esse valor é fictício, fruto de um erro. Melhor propagar a exception e deixar o chamador lidar com o problema.

    • @salyut1
      @salyut1 5 месяцев назад +2

      @@victorbiasibetti Eu entendo que deveria ser desse jeito. Acho que apenas maluco não usa um instanceof para trabalhar as diversas exeções (em vez de colocar um try catch dentro do outro).

  • @alexmarchand1992
    @alexmarchand1992 5 месяцев назад +40

    "raios gamas podem flipar bits" mano imagina o azar do cara investigando bug por isso kkkkk

    • @jeanoliveiiira
      @jeanoliveiiira 5 месяцев назад +3

      pior que ja rolou! kkkkk um amigo meu que trabalhava com dispositivos que sao expostos a isso relatou

    • @AlexeiDimitri
      @AlexeiDimitri 4 месяца назад

      Foi um exemplo infeliz dele
      Para esse tipo de problema vc tem tratamento já no hardware, leia-se ECC

  • @RenascenceOfficial
    @RenascenceOfficial 5 месяцев назад +4

    Bom, Java tem um handler que me agrada muito. Me ajuda demais.
    Além de haver um handler (try...catch), temos a cláusula throws, que pode ser fornecida a métodos para informar a chamadas que aquele método pode lançar determinada exceção.
    A cláusula " throws" é seguida de uma exceção que podemos lançar. O compilador reclama muito quando não tratamos ela no chamador do método, e nem conseguimos rodar a aplicação.
    Além disso, temos a cláusula " throw", onde podemos decidir lançar uma nova exceção de dentro do método ou de dentro do catch, onde podemos relançar nossa exceção ao nível superior, caso não tenha como nos recuperar de um erro no método.
    Java nos permite definir vários catchs para um único try, ou então usar um padrão multicatch, onde apenas uma catch pode pegar várias exceções.
    E o recurso mais legal que amo no java é o try-with-resources, que elimina a necessidade de escrevermos blocos finally para limpar recursos.
    Claro que nada nos impede de escrever catchs ou finallys em try-with-resources, ele apenas tira essa preocupação.
    Eu acho que java é extremamente robusto. Me serve e muito pra muita coisa e me ajuda demais com essas operações críticas.
    Eu trabalho com desenvolvimento de softwares de gestao administrativa e tipo, não posso ter falhas. Então Java me ajuda muito nesse lado. Fora os recursos e o desempenho da linguagem que faz os olhos brilharem 🥹
    Aprendam Java, é magnífico!

    • @paulorockz6899
      @paulorockz6899 4 месяца назад +1

      Só uma observação nesse seu comentário, tudo que você citou aí existe também no C# e algumas outras linguagens tipadas. Não é unicamente do Java. Jamais se apegue exclusivamente a uma linguagem.

    • @HenriqueGustavorsrs
      @HenriqueGustavorsrs 3 месяца назад

      @@paulorockz6899 óbviamente, pois c# literalmente copiou Java

  • @pedroAWEJNF2O
    @pedroAWEJNF2O 5 месяцев назад +49

    9:56 - Trabalha cansado, com 3h de sono, fumando 9 prensados por dia, participando de 5 reuniões por dia, foda

    • @mcardosodev
      @mcardosodev 5 месяцев назад +13

      isso pareceu muito específico, você ta bem?

    • @manoeldibrito
      @manoeldibrito 5 месяцев назад

      Cara, pior fase da vida é essa ...Passei muito por isso.

    • @chanela6135
      @chanela6135 5 месяцев назад +4

      Só parar de se drogar, espero ter ajudado 👍

    • @pedroAWEJNF2O
      @pedroAWEJNF2O 5 месяцев назад

      @@chanela6135 Tem razão!

    • @joaocarlos-bq4ks
      @joaocarlos-bq4ks 5 месяцев назад +1

      @@pedroAWEJNF2O quando tu passa uma semana criando um componente super customizado , ai vem o QA enchendo o saco por causa da cor do botão , ou não executa a animação que ele queria

  • @bacon4life
    @bacon4life 5 месяцев назад +13

    Galego, acho que você errou no comentário sobre o finally do inner_method. É impossível aquela função retornar None, o return type dela pode ser corretamente declarado como int.
    O finally não tem um return None implicito. Quando o ZeroDivisionError for levantado, ele vai ignorar o except ValueError, pois não é um ValueError, e como não tem mais nenhum except, a exceção vai subir na call stack, porém antes de subir, o finally tem que ser executado. Após o finally ser executado, o erro é re-levantado, sem retornar o None. None nunca é retornado aqui.
    A não ser que você coloque um return None no finally, mas ai sua função sempre vai retornar None, independente de ter uma exception no try ou não.

  • @seoky6
    @seoky6 5 месяцев назад +166

    Resumindo, o problema não é o try/catch, mas sim o Dev ruim em estrutura de dados.

    • @AntonioLopes-tn9wd
      @AntonioLopes-tn9wd 5 месяцев назад +6

      isso e o basico de execucao de codigo

    • @carloshenrique-ov5nk
      @carloshenrique-ov5nk 5 месяцев назад +5

      Então logo Goto tbm não é 😉

    • @GutoGalego
      @GutoGalego  5 месяцев назад +22

      Mais ou menos. Javascript por exemplo é meio ruim, mas é inevitável. Um dev bom em javascript consegue fazer aplicações boas mesmo com o JS sendo ruim.
      Try catch é ruim e é evitável, as linguagens que os devs mais gostam de usar (segundo a pesquisa do stackoverflow) não tem try/catch.

    • @Gustavo054
      @Gustavo054 5 месяцев назад +4

      Try Catch qnd vc não sabe o que é o erro, quando vc sabe é perfeito.

    • @rafael33264
      @rafael33264 5 месяцев назад +1

      @@GutoGalego Mas quem que usa java script puro man? a maioria dos dev "java script" usam tyepscript, java script praticamente só é usado de forma didatica enquanto o dev ainda ta estudando programação..

  • @jeanfraga8842
    @jeanfraga8842 5 месяцев назад +1

    Fico feliz de saber que eu já usava o throw só pra ir lancanço o erro pra cima e o try catch apenas na camada de apresentação pra poder saber e localizar o que tinha acontecido

  • @ailuros_
    @ailuros_ 5 месяцев назад +4

    5:14, A velha pegadinha do strongly typed x dynamically typed. Python é FORTEMENTE e DINAMICAMENTE tipado.
    Sobre a forma de uso de try/catch isso é uma daquelas coisas que… depende dos cenários (como quase tudo em nossa área). Eu penso o contrário, exceptions não deveriam ser prioritariamente tratadas in-local (exceto se há uma boa razão para isso), até pelo fato de algumas vezes não fazer sentido (out of memory). Na maioria das vezes é melhor deixar propagar e deixar a camada mais acima tratar e lidar com esses erros, talvez tenha algum mecanismo ESPECIALIZADO na camada que trate os cenários de erros. Tentar tratar a maioria ou todas as exceptions no local onde elas ocorrem leva àquele local a ter mais ruído/sujeira de código, aumenta a complexidade, pois em alguns casos no tratamento haverá logging envolvido ou algum mecanismo de tracing e, consequentemente, importação de módulos e código que proveja essas funcionalidades causando aumento do grafo de DEPENDÊNCIAS não essenciais para aquela rotina. Além do ruído e distração causada, há também impacto no refactoring futuro devido às dependências. Propagando para cima é muito mais legível e possibilita uma estratégia muito mais modular e organizada/especializada. Um exemplo bem legal disso é o Django Rest Framework que nas classes de View tem um método onde você registra um manipulador especializado para tratar as exceptions que ocorrem nas chamadas daquele View set (pena que várias pessoas desconhecem).
    Quanto a forma que o Golang faz… well… sendo um programador de Go também, eu diria que há melhores formas de tratar erros. No final do dia, algumas dessas coisas depende muito da visão de cada sobre design.
    Desculpa o textão e bom vídeo! ;)
    P.S.: goto sendo considerado ruim não é consenso. Há cenários onde faz muito sentido do ponto de vista pragmático. Mas eu mesmo não uso (falando em C)

  • @justrelax6144
    @justrelax6144 5 месяцев назад +23

    putz. assisti o video todo para descobrir que já é do jeito que eu programo.
    uso um try catch só nas controller e fazendo ali o tratamento de erro pra retornar ao usuario, e na camada de services fazendo a validação, tratamento, e requisição dos dados e avisando seus respectivos erros com throw error

    • @carloshenrique-ov5nk
      @carloshenrique-ov5nk 5 месяцев назад

      @@justrelax6144 MELHOR não usar pelo oq ele explicou

    • @marcelogouveiadeassis230
      @marcelogouveiadeassis230 5 месяцев назад +2

      faço parecido aqui com FastAPI (Python) sempre que tenho alguma exceção eu dou um raise independente da onde esteja rodando, e dai tem um handler global de erro, que retorna o erro pro usuário.

    • @chlima88
      @chlima88 5 месяцев назад +11

      Faço a mesma coisa em Java. Essa é na minha opinião a melhor solução. O Spring tem um recurso chamado Controller advice que permite vc adicionar um ErrorHandler que é executado automaticamente nos controllers. Vc nem precisaria de try/catch

    • @fabiodosreisvianadasilva6850
      @fabiodosreisvianadasilva6850 5 месяцев назад

      @@chlima88 Isso é muito top, deixa o código muito limpo.

    • @OFilipeDias
      @OFilipeDias 5 месяцев назад

      @@chlima88 fastify tbm, uso o erroHandler que quando da erro ele executa automatico. Show de mais

  • @Set_Abominae
    @Set_Abominae 5 месяцев назад +4

    Interessante acompanhar esse assunto. Sou programador Cobol e realmente, GO-TO é uma grande merda que a gente tinha que lidar lá atrás e era muito chato para debugar. Por esse tipo de problemas criou-se uma convenção de não usarmos go-to, ever!
    E o mais interessante desse vídeo, é que o "como consertar" é exatamente como fazemos no Cobol, para ficar mais legível e evitar bugs.
    Engraçado que algo que já faziam décadas atrás, estão sugerindo e implementando atualmente(result pattern)... O universo do software é realmente em ciclos né... kkkkk
    Aliás, parabéns pelo ótimo conteúdo como sempre Galego!

  • @matheusbarreto7656
    @matheusbarreto7656 3 месяца назад

    Mano, já acompanho seus vídeos tem um tempo, e tem me ajudado bastante seus conteúdos. Além da didática, a maneira da exposição dos tópicos é ótima!

  • @gabrielcastro4813
    @gabrielcastro4813 5 месяцев назад +7

    5:14 Python tem tipagem forte e dinâmica

  • @dhanielr
    @dhanielr 5 месяцев назад +2

    Muito bom vídeo, foi uma das coisas que mais gostei em Go quando comecei a alguns anos atrás, é o fato do error não ser um objeto concreto na linguagem, podendo interagir com o tipo dele de forma mais livre, mas ainda assim existe uma espécie de "try/catch" em go. Mesmo em funções que não retornam erros diretamente, existe uma possibilidade de uma exception ocorrer. Se forem funções de pacotes padrões do Go provavelmente o motivo é que parte do processo dessa função está acontecendo fora do escopo em que o runtimer do go pode vistoriar ou acessar, ou se for um pacote criado por você ou pela comunidade, pode ocorrer se a função "panic" for chamada. Basicamente ela é para funcionar de forma similar as outras linguagens, mas no momento em que a exception quebra a pilha e encerra o programa, ela basicamente recebe um any e vai quebrar a pilha de execução inteira e retornar o que ela recebeu como exception, mesmo que nem seja uma, inclusive. Caso esse panic ocorra, vc pode usar o defer juntamente com a função recover para poder fazer algo em cima desse erro que gerou o panic. Eu particularmente acho essa parada de Panic/Recover meio dúbio, mas entendo a necessidade dela na linguagem. De qualquer maneira, a forma padrão de se lidar com erros em Go é como descreveu, e realmente evita bastante esse problemas de Try/Catch.

    • @FernandoSilvaSousa
      @FernandoSilvaSousa 4 месяца назад

      Em basicamente todas as linguagens o erro é um tipo concreto

    • @dhanielr
      @dhanielr 4 месяца назад

      @@FernandoSilvaSousa acabei esquecendo o NÃO na frase e invertendo a minha colocação, em go, o typo error não é um tipo concreto e sim uma interface

  • @vitorbrussolo9651
    @vitorbrussolo9651 5 месяцев назад +12

    Me tira uma duvida boba mais pra mim e importante (ela vai na contra mao do video com seu raciocionio)
    1 - Try-catch sem throw: Se você não usar throw dentro do bloco catch, o erro é capturado e tratado ali mesmo? Se sim o programa continua a execução normalmente após o bloco catch ?
    2 - Throw dentro do catch: Se você usar throw dentro do bloco catch, a exceção é lançada novamente e propagada para outros blocos catch mais acima na pilha de chamadas, até que seja capturada novamente ou até que não haja mais blocos try-catch ?
    3 - A exceção lançada com throw continuará subindo na pilha de chamadas até encontrar um bloco try-catch que a capture ? Se ele não encontrar, será tratada como uma exceção não capturada e pode terminar a execução do programa chegando ate o main?

    • @renejunior661
      @renejunior661 5 месяцев назад +1

      pelo menos nas linguagens de JVM (Kotlin e Java) que tenho conhecimento o bloco continua sim, se não houver o throw ou o return o fluxo continua normalmente.

    • @leonardovee
      @leonardovee 5 месяцев назад +3

      A resposta eh sim para todas as duvidas

  • @gbcgiovanni6885
    @gbcgiovanni6885 4 месяца назад

    Ótimas reflexões. Interessante como um simples try-catch pode gerar discussões.
    Em um proximo projeto vou usar alguma variação desse result pattern.

  • @quilamcz
    @quilamcz 5 месяцев назад +9

    Os vídeos desse cara sempre apontam a tecnologia como problemática, quando na verdade é a pessoa que não sabe utilizar.
    Nos exemplos, temos vários métodos com apenas um try/catch, desse modo, o que esse método "pode" retornar deve ser tipado independente se você usa try/catch ou qualquer outra gambiarra.
    Você só deve parar de usar try/catch se quiser que sua aplicação estoure erros sem dar contexto pro usuário, e claro, quando você não sabe usar a ferramenta.

    • @GutoGalego
      @GutoGalego  5 месяцев назад +1

      É que eu acredito que certas formas de se fazer software são melhores que outras. O cara que criou o Null diz que null foi um erro. As linguagens evoluem e mudam. Python permitia antes mudar o valor de True e False. Agora não pode mais, as coisas evoluem conforme a indústria descobre maneiras melhores de fazer as coisas.
      Eu acredito que existem maneiras melhores

    • @GutoGalego
      @GutoGalego  5 месяцев назад +1

      Um bom exemplo é typescript. Eu acho que eu não faria código em JS puro pra absolutamente nada, typescript é só melhor na minha visão.

    • @quilamcz
      @quilamcz 5 месяцев назад +5

      ​@@GutoGalego Eu entendi a questão da evolução, as pessoas evoluem e a tecnologia junto com elas.
      O que eu estou com problema em entender é; como adicionar verbosidade ao algoritmo pode ser melhor do que usar tryCatch.
      A verbosidade extra pode até tornar o código mais legível, mas o torna menos seguro, afinal, o que você programou ainda está sujeito a erros, erros que o tryCatch poderia tratar ou ao menos te gerar um log.
      Se o assunto do vídeo é clean code, sinto muito pois entendi errado, achei que era tecnologia defasada.

    • @AlexeiDimitri
      @AlexeiDimitri 4 месяца назад

      Bom então vamos fazer o seguinte
      A partir de agora vc só pode usar assembly, nada de linguagens de alto ou médio nível.
      Agora, quero ver vc dizer que a culpa é do programador.

    • @quilamcz
      @quilamcz 4 месяца назад +1

      @@AlexeiDimitri você esqueceu de dizer que isso é uma suposição? Ou realmente é para eu usar somente assembly? Em qualquer caso, percebe-se que a falta de seguir certas regras, neste caso a gramatica, faz com que o programador cometa erros.
      Tu quer dizer que assembly é ruim? Independente das habilidades do programador? Por favor, deixe-me entender seu raciocínio neste comentário.

  • @lucaspizol3250
    @lucaspizol3250 5 месяцев назад

    Legal o conteúdo! Quando trabalho com node, gosto de criar um adaptador de rotas (inverter a dependencia do express por ex) e colocar nele o trycatch. Depois crio classes de erros que eu gostaria de dar throw (BadRequest, NotFound, Conflict, etc...) e faço uma tratativa para enviar um body personalizado pro front. Dessa forma, se receber um erro 500 quer dizer que realmente deu merda, mas como eu tratei lá no route adapter, não vai bugar tudo

  • @octaviobar91
    @octaviobar91 5 месяцев назад +4

    Quem tem problemas em usar try/catch tem que estudar mais sobre tratamentos de erros... Javascript pode até não ser a melhor linguagem, mas tem formas simples de tratar todos os erros.
    Não é um problema ter blocos try/catch um dentro do outro, mas é necessário fazer o tratamento correto e subir as exceções para o local onde serão processadas, fazendo isso não existe os problemas comentados no vídeo. Tem que saber como a linguagem lida com as exceções e tratá-las.

  • @KodornaRocks
    @KodornaRocks 5 месяцев назад +9

    Pior do que usar try catch é não usar. Tem programador que se preocupa tanto com a qualidade do código que entrega que até esquece do software que está fazendo.

    • @lorenzomarques566
      @lorenzomarques566 3 дня назад

      Tem cara que fica com essas frescura de não querer usar try catch, seguir clean code e boas práticas(Que diga-se de passagem, muitas vezes é só um padrão que aquele ou outro dev criou pq acha mais bonito) a risca que no fim das contas acaba fazendo um monte de volta e um código mais complexo que o necessário só pra não usar isso.

  • @PedroHawk1
    @PedroHawk1 Месяц назад

    Ontem mesmo eu vi uma discussão antiga sobre esse assunto no canal ThePrimeTime. Mas lá, o foco dele não era no try/catch, era em Exception. Segundo ele, Exceptions não deveriam existir, e todas as exceções de fluxo deveriam ser retornadas no valor de uma função, porque esse negócio de ficar subindo Exceptions implicitamente é muito perigoso.
    Nos comentários lá, as pessoas dizem que o problema dele é especificamente com as Exceptions não verificadas, e que muitas linguagens (como Java, por exemplo) tratam disso colocando a exceção na assinatura de uma função.

  • @icarovieira4479
    @icarovieira4479 5 месяцев назад +1

    Sem mencionar que sair do fluxo principal ou contexto principal é extremamente imperformático, sendo considerado uma má prática por algumas linguagens antigas. É preferível usar return true ou false. Linguagens como Go sanam isso utilizando erro em formato de variável sem sair do contexto ( main ).

  • @alguem-dev
    @alguem-dev 5 месяцев назад

    Primeiramente se você não tem um fallback que seja um retorno valido, você não deveria capturar e tratar o erro. Se a função que chama não souber tratar o erro, ela deve ser interrompida, assim como todas as funções anteriores.
    Caso seja uma exceção inesperada deve ser capturada por um handler generico ao invés de matar a aplicação.
    Caso seja esperada e impossivel de resolver como por exemplo uma requisição http onde um campo do body que deveria ser um numero é uma letra, você deveria capturar, e jogar uma exceção enriquecida com detalhes do problema no contexto dele: (InvalidPhoneException, causedBy IllegalArgumentException). Nessa situação nada além de dar o feedback na response deveria acontecer. então você só vai capturala e tratala na hora que for buildar a response, nesse momento todas as funções anteriores já foram desepilhadas.
    Caso seja esperada e souber resolver, captura resolve e retorna a solução.
    A mesma coisa é no Go, se a função que chamou não souber tratar o erro, retorna o erro, para a anterior tentar. O que não gosto do Go é isso, tem que escrever toda vez if (err!=nil ) return err, quando que em outra liguagens é só não capturar o erro, que o comportamento é o mesmo.
    Existem exceções mas no geral é isso.

  • @umlucasalmeida
    @umlucasalmeida 5 месяцев назад

    Tive alguns problemas com Try Except em um código python por esse exato motivo. Essa abordagem do Go é bem interessante. Obrigado pela dica!

  • @arodasiora
    @arodasiora 5 месяцев назад

    Interessante! Estava justamente utilizando try e catch quando o YT me recomendou esse vídeo kkkk +1 inscrito! Sempre muito bom está atualizado

  • @luizjrrd
    @luizjrrd 21 день назад

    usar um async handler com um middleware pra error handling não seria uma boa solução?

  • @kapzsisag
    @kapzsisag 5 месяцев назад

    Tá aí um dos motivos de eu gostar tanto de Go - erros são valores e você é obrigado a tratá-los (além de que fica sempre explícito na declaração de uma função caso ela possa retornar um erro)

  • @interpretadesign
    @interpretadesign 5 месяцев назад +8

    Uns dizem que não pode usar else, outros try/catch. Qualquer recurso de fluxo de controle que for mal utilizado vai resultar em código ruim e pouco previsível.

    • @lenickramone
      @lenickramone 5 месяцев назад

      Eh bem previsível q vai ser ruim, rs

  • @AndiichiDev
    @AndiichiDev 5 месяцев назад

    meu deus, esse video caiu como uma luva para mim kkk to começando a POO e try/catch é beem necessario , e to estudando python. mt obrigadaa

  • @AlvesNamor
    @AlvesNamor 4 месяца назад

    Muito bom, inclusive outro grande problema é que exceptions sobem o consumo de recursos por carregar a stack trace por N camadas.

  • @LucasAlfare
    @LucasAlfare 5 месяцев назад

    Gente, alguma ideia de padrão pra ter esse tratamento de erros melhorado no Kotlin? (Puro ou Android)

  • @pedrocirilo2051
    @pedrocirilo2051 4 месяца назад

    O que eu uso bastante é criar os erros extendendo da class Error pra depois controlar no catch com o instanceof.

  • @misaelkelviny
    @misaelkelviny 5 месяцев назад

    Caramba q legal, li sobre isso hj no livro arquitetura limpa do uncle bob, ele cita esse artigo do Dijkstra e fala a respeito. Que massa!

  • @Richsan
    @Richsan 3 месяца назад

    Na real é bem comum em frameworks haver um módulo chamado exception handler que visa tratar qualquer exception que subir sem tratamento, tem que haver isso pq chega uma hora que fica repetitivo tratar o mesmo tipo de erro do mesmo jeito em vários lugares

  • @IgorSprovieri
    @IgorSprovieri 5 месяцев назад +2

    Ninguém usa try catch dentro de try catch. Geralmente se usa o try catch somente para não quebrar a aplicação com erros desconhecidos e os erros conhecidos são retornados normalmente

    • @AlexeiDimitri
      @AlexeiDimitri 4 месяца назад

      Tudo depende da lógica que vc tá usando e do fluxo de controle

  • @zacao
    @zacao 5 месяцев назад

    Try/catch não é péssimo, exceto se você estiver usando ele da forma errada, isto é, pra fazer controle de fluxo de execução (ao invés de usar if's) ou silenciando erros. De igual forma, propagar erros através da call stack não é um anti-pattern, pelo contrário, auxilia ao usuário da sua API tratar o erro na camada de abstração correta.

  • @techtiribas
    @techtiribas 5 месяцев назад +4

    to na pré-estréia 🤩

  • @reidosreis4k
    @reidosreis4k 5 месяцев назад +1

    Muito bom o vídeo, concordo que try catch não é o ideal na maioria das vezes. Mas o que mais me deixa puto é o pessoal falando que o problema não é o try catch, e sim o programador. Pessoal ignora qualquer defeito de uma linguagem falando que a culpa é da pessoa que tá usando, algo que é muito injusto. Se o programador de hoje em dia comete os mesmos erros que o programador de 30 anos atrás, não é a pessoa, é a tecnologia, mas o pessoal não aguenta outros falarem mal da linguagem favorita deles

  • @christianlinux8283
    @christianlinux8283 5 месяцев назад

    sobre python: em resumo sobre os linters se quiser verificar tipos e qualidade de código na hora do desenvolvimento utilize o mypy (se possível strict), e o ruff. Se quiser verificar tipos em execução o pydantic faz o trabalho.
    python é uma linguagem de tipagem dinâmica e forte.

  • @SamuelAndradeGTutos
    @SamuelAndradeGTutos 5 месяцев назад

    Pior que, até no Java, onde tu tem a tipagem certinha e ele obriga a colocar o throws na assinatura do método, todo esse argumento vale, porque pode ter levantado um RuntimeException ou algo assim que não é obrigado no throws. E, pior que, se colocar pra obrigar, quebra tudo kkk

  • @jeanmelo5786
    @jeanmelo5786 5 месяцев назад +2

    bom vídeo Galego! traz um vídeo ensinando a configurar um ambiente python minimamente decente

  • @hermersonaraujo9378
    @hermersonaraujo9378 5 месяцев назад

    Mano se tivesse mencionado a questão do uso de memoria para manter a stack trace do erro quando ele é lançado nas camadas mais internas até faria sentido que vc ta falando. O código que vc mostrou tem tantos problemas que eu não acho que é culpa do try/catch kkk. Mas é muito bom o pattern do GO do either ou result.

  • @carlosgabriel6296
    @carlosgabriel6296 5 месяцев назад

    afinal, onde caralhos eu trato o erro? lá em baixo ou lá em cima quando borbulhar?

  • @jailsonmendes4983
    @jailsonmendes4983 5 месяцев назад

    Em 5:42: tecnicamente falando, inner_method NUNCA retorna, então não faz definir um return type para ela. Ela SEMPRE vai estourar um ZeroDivisionError e nunca retornar.
    Se você quiser ser preciso, o correto é definir inner_method como def inner_method() -> typing.NoReturn, ou então, em python3.11+, typing.Never, que são os mesmos tipos utilizados para funções que ficam em loop infinito:
    def main() -> typing.Never:
    while True:
    pass

  • @jscomputadores1049
    @jscomputadores1049 5 месяцев назад

    eu como uso c# nao tenho esse problema, pois é facilmente resolvido entre client e api com, inclusive uso muito return em void para justamente parar a execução de codigo quando algo esta faltando/errado, é so saber usar as ferramentas da linguagem de maneira apropriada

  • @hspadim
    @hspadim 5 месяцев назад

    Galera em C usa goto para lidar com exceções. Esse tipo de implementação lembra try/catch apesar do mecanismo de “rewind” ser diferente
    Além disso, em linguagens que tem a sugar syntax `?` leva a erros mais sutis na hora de debugar o erro no log (devido a falta de trackback)

  • @hyungtaecf
    @hyungtaecf 5 месяцев назад

    Eu não entendo como seria diferente das linguagens que tem try-catch mas tem null-safety. Porque elas não te deixam retornar null quando a função diz que retorna um valor, mesmo usando try-catch

  • @RicardoSierrarj
    @RicardoSierrarj 5 месяцев назад +4

    hahah péssimo porque não sabe usar Exceptions hahahaha
    Muito raro os casos que realmente precise usar try e catch assim. igual falou. Consigo pensar agora quando precisar dar um rollback

  • @AlexeiDimitri
    @AlexeiDimitri 4 месяца назад

    Esse tipo de coisa acontece pq vc tá pensando de forma sequencial numa linguagem nativamente assíncrona e funcional.
    Em geral se vc tá usando async/await é pq vc tá fazendo errado.
    Como vc lida então com exceções e consegue controlar o fluxo de trabalho? Simples, usando Promises e usando máquina de estados.
    Vc usa os promises para mudar o estado da sua aplicação
    E a sua aplicação basicamente reage a essas mudanças de estado
    Como vc faz o usuário participar disso? Sua aplicação mapeia a interface para o estado da aplicação
    E promises fazem o trabalho de sincronizar o estado local com o estado no servidor.
    Ë o mesmo motivo pelo qual um programador burro pega um I/O que é assíncrono e dá um jeito de torná-lo síncrono. Vc tá ocupando recursos que não deviam estar travados e deixando a aplicação menos responsiva, pq o thread principal do JS tá esperando o resultado daquele I/O.

  • @FernandoSilvaSousa
    @FernandoSilvaSousa 4 месяца назад

    De vez em quando a Internet dá uma sequelada, try catch não é nenhum pouco parecido com Goto, que podia avançar, a exception só retorna, ele tá mais pra um if + return implícito, já que de fato retorna um objeto.

  • @MarleySacramento-x3l
    @MarleySacramento-x3l 5 месяцев назад

    assistindo o vídeo como se tivesse entendendo alguma coisa ( não entendi nada), mas sabendo que daqui um tempo vou voltar e entender tudo

  • @marcopeli3417
    @marcopeli3417 Месяц назад

    Acho que o problema é achar a melhor linguagem para a situação específica. As linguagens compiladas e dinâmicas tem vantagens e desvantagens. As linguagens dinâmicas permitem codificar um script rápido ou uma automação simples de forma muito prática! Se vamos para um sistema grande e complexo, a linguagem estática ajuda a identificar muitos problemas em tempo de compilação. Por isso criaram o Typescript para o JS, por isso a performance do GO é muito superior, por isso o tratamento dos erros é totalmente diferente, etc...

  • @diegocantelli
    @diegocantelli 5 месяцев назад +10

    O problema não é o try catch, MAs sim como você usa. Esses exemplos aí obviamente são um mal uso do recurso, mas não que o try catch seja o problema. O título ficou bem sensacionalista e a explicação bem tendenciosa.

  • @CaioLemos-GraduacaoNerd
    @CaioLemos-GraduacaoNerd 5 месяцев назад

    Tá maluco, teu conteúdo é bom demais meu querido

  • @pandasoli6581
    @pandasoli6581 5 месяцев назад

    Ou vc pode usar "result, _ := divide(10, 0)". Claro que quando vc faz isso as vezes costuma ser com motivo, mas pode acontecer. Acho que Rust lida com erros de uma forma muito mais "chata" mas bem mais efetiva

  • @costathoughts
    @costathoughts 2 дня назад

    Try-catch é pesado, até por que no java o mesmo recolhe toda a stack para fazer o print nessa info... Por isso que eu acredito que devemos de fato tratar erro como um tipo, eu realmente amo esse approach do golang.

  • @JeanCarlossp
    @JeanCarlossp 5 месяцев назад

    Esse principio de "não mentir" um comportamento é semelhante ao principio de substituição de Liskov no SOLID.

  • @EuclidesFRezende
    @EuclidesFRezende 5 месяцев назад

    Falaram mal do GOTO e a solução mais elegante que conheço para erros é vinda justamente da linguagem que mais usa GOTO: BASIC.
    Algumas versões tem algo simples assim:
    ON ERROR GOTO LINHA XXXXXX
    Na primeira linha de seu programa você fazendo isso, desviará qualquer erro para aquela linha (XXXXXX). Lá você põe a rotina que você usará para no mínimo te mostrar o que houve. Sem Try e Catch antes do Try e Catch para saber se houve error no TRY ou no CATCH....
    XXXXXXX PRINT #LIN, #ERR, etc...
    Algo parecido com isso, lhe mostraria a linha onde houve o erro e a mensagem de erro. Simples e funcional.

  • @firezinfds
    @firezinfds 2 месяца назад

    no type script ele reclamaria avisando que o retorno pode ser nulo

  • @allefgaruda
    @allefgaruda 5 месяцев назад +4

    Um dos poucos vídeos que discordo fortemente do galego, esse pattern de result ofusca completamente a stack trace quando um erro acontecer, citando java, tenho a sensação que é como fazer try catch pra lidar com erros ao invés de exceptions
    Linguagens que já tem algo parecido nativamente ok, como go e rust, mas se não, vejo a aplicação como uma muleta pra uma certa incapacidade de algum sênior em transmitir o conhecimento necessário de estrutura de dados aos mais novos

    • @cca9837
      @cca9837 5 месяцев назад

      Não oculta, pelo menos em JS é só retornar um new Error()

    • @allefgaruda
      @allefgaruda 5 месяцев назад

      ​@@cca9837 mesmo que ele retorne um error, a stack trace vai ser do momento que lançar o erro (throw error) e não do momento que o erro aconteceu

    • @andredesantacruz
      @andredesantacruz 4 месяца назад

      @@allefgaruda o colega acima claramente não sabe o que é o stack trace :x

  • @hiperesp
    @hiperesp 5 месяцев назад

    1:40 sempre pensei nisso, tava até na dúvida se tinha um try catch reverso, onde a exception vem antes justamente pra facilitar a leitura

  • @gabrielguerrastudio
    @gabrielguerrastudio 5 месяцев назад

    O exemplo inicial, com um try/catch dentro de outro try/catch não é bom, pois já indica um problema de design, que deveria ser corrigido antes de tudo.

  • @AlesaGillespie
    @AlesaGillespie 5 месяцев назад

    Dê semantica pros errors: validation, error, unexpected, unavailable. Cria uma função pra mapear isso na camada superior e lançar o status correto. Faz mais uma validação pra garantir que os dados vão ser executados corretamente na regra de negocio. Simples assim.

  • @felliperodriguessantos3114
    @felliperodriguessantos3114 5 месяцев назад

    Eu sempre uso o try-catch. Caso dê algum erro eu aciono minha tabela de logs para salvar a cagada que rolou. Isso simplesmente me salva de ficar procurando erros quando eu recebo algum ticket.

  • @brendonoliveira2142
    @brendonoliveira2142 5 месяцев назад

    Não gosto da ideia de "misturar" o fluxo de exceção com o fluxo esperado, eu prefiro disparar uma exceção e criar um tratamento isolado para lidar com ela isolando responsabilidades.

  • @cleitonluiz7136
    @cleitonluiz7136 4 месяца назад

    Eu não sei se é uma boa idéia usar "padrões" para emular comportamentos de outras linguagens ao invés de usar melhor aquilo uma linguagem já oferece de maneira nativa.

  • @joaohang9739
    @joaohang9739 5 месяцев назад

    Cara vc acha que mesmo tratando o erro no fim é valido deixar ele estorar para que ferramentas de captura de erro possam mostrar o stack trace ?
    Algo como:
    except Exception as error:
    logger.error("Error XYZ")
    raise error

  • @GabrielLima-lq3zw
    @GabrielLima-lq3zw 5 месяцев назад

    Do meu ponto de vista, o problema com o try/catch é o exagero.
    Eu mantenho sempre um padrão nos meus códigos que é o de deixar quebrar sempre que possível.
    Eu vou ter apenas no nível mais alto da aplicação, e apenas em casos onde preciso dar rollback em uma transaction do banco e afins, caso contrário, nem isso, deixo pro meu "try catch global" lidar com o erro, registrar logs e retornar uma mensagem de erro adequada ao cliente.

  • @imtheil
    @imtheil 5 месяцев назад

    Você tem o melhor canal da bolha, parabéns!

  • @dev-sergio
    @dev-sergio 5 месяцев назад

    Nunca gostei de usar try catch como uma estrutura para error handling. Estes dias precisei usa-lo para retornar um objeto diferente caso a API estourasse uma excessão, e para este caso, ele foi bem últil.

  • @civicmugenlxs
    @civicmugenlxs 5 месяцев назад

    Em .Net 5 eu costumo a utilizar um middleware para tratar erros na aplicação, o que você acha dessa abordagem?

    • @angelopilotto3323
      @angelopilotto3323 5 месяцев назад

      Muito bom! Limpa demais o código, principalmente em controllers, quando o status http retornado for sempre o mesmo pra um tipo de erro

  • @guimatech9561
    @guimatech9561 5 месяцев назад

    Não sei se é porque estou muito acostumado a ver try/catch que não vejo as coisas que falou como problema, contando que não se minta o retorno, tenha retorno padronizado e devidamente documentado.

  • @mikaiodev
    @mikaiodev 5 месяцев назад

    Programo em Python e nunca tinha visto esse result pattern mas faco isso instintivamente porque já sofri muito com esse tipo de problema kakaka error_, result = funcao_faz_algo(param) if error_ ....

  • @matheusaraujo6445
    @matheusaraujo6445 2 месяца назад

    Tive exatamente o mesmo problema em prod por retornar um valor inconsciente em um catch

  • @pietroviske
    @pietroviske 4 месяца назад

    Esse exemplo do post já não faz sentido porque o cara botou um try catch dentro de outro só pra mudar a mensagem de log. Se isso não é importante (quase nunca é) vc pode sempre usar apenas um try/catch e o catch ser log generico como "console.error('error', error.toString)" ja que a mensagem do erro ja vai dizer o que aconteceu.

  • @matheusaraujo6445
    @matheusaraujo6445 2 месяца назад

    Eu gosto muito de Go, mas acho muito estranho usar no Javascript. Gosto da ideia do lint ou algo do tipo mesmo

  • @rafaelschueng
    @rafaelschueng 5 месяцев назад +3

    Porquê diabos as pessoas não focam em usar Guards para evitar usar Try/Catch? Eu nunca entendi essa tara estranha das pessoas de querer garantir o resultado sem garantir que o processo esteja correto. Try/Catch só se usa em condições que seu código não pode garantir um fator externo como um banco de dados falhar na inserção de dados e mesmo assim você pode usar um circuit-breaker em situações assim(Aqui tem que ter atenção).
    PS: Leiam sobre programação defensiva.

    • @hyungtaecf
      @hyungtaecf 5 месяцев назад

      Mas isso é óbvio, ele usou try-catch assim só para demonstrar. Realmente try-catch só se usa quando se recebe dados externos.

    • @dfeprado
      @dfeprado 5 месяцев назад

      Tá, e aí você faz o quê quando seu guard falhar?

    • @rafaelschueng
      @rafaelschueng 5 месяцев назад

      @@dfeprado Você só aceita que não sabe os detalhes do que você esta programando e também aceita que não testou o seu software adequadamente.
      Segundo a definição de guards segundo a Wikipedia: "Em programação de computadores, uma "Guard clause" é uma expressão booleana que deve ser avaliada como verdadeira se a execução do programa deve continuar no branch em questão. Independentemente de qual linguagem de programação é usada, uma "Guard Clause", é uma verificação de pré-condições de integridade usada para evitar erros durante a execução."

    • @alexandreabto
      @alexandreabto 5 месяцев назад +2

      São estilos diferentes (LBYL e EAFP), mas não quer dizer que é pra garantir um "resultado que encaixe". Em resumo, eu diria que a diferença é sobre tratar a possibilidade de erro antes ou tratar o erro depois, se ele acontecer. O que tem que ser feito com o erro vai ser o mesmo para os dois casos: tratar como deve ser tratado pra cada caso. Essa história de usar o try/catch pra mascarar não é problema de try/catch. É do programador mesmo.

    • @rafaelschueng
      @rafaelschueng 5 месяцев назад

      @@alexandreabto Exatamente. Eu prefiro mil vezes considerar usar Try/Catch numa situação onde eu estou querendo salvar um dado num banco de dados e eu não posso garantir que fulano ou beltrano não vá tropeçar nos cabos de energia do servidor e perder conexão do que usar Try/Catch deliberadamente para qualquer função que eu chamar na garantia de que elas não falhem. Com apenas Guards eu consigo esgotar quase todas as possibilidades de erros na função que eu tento executar.
      Linguagens funcionais tentam lidar tratamento de erro usando guards/pattern matching e torna as coisas tão simples quanto.

  • @biancabarreto1756
    @biancabarreto1756 Месяц назад

    O correto na verdade é usar try catch só quando precisa e deixar quebrar pra não mascarar tudo

  • @igorferreira7137
    @igorferreira7137 3 месяца назад

    Concordo Andre. O futuro é essa internet paralela

  • @pedrolucasdeoliveiralara8199
    @pedrolucasdeoliveiralara8199 5 месяцев назад +7

    12:27 Esse pattern é bem inútil. Teu último código poderia ser simplesmente assim com try catch que daria exatamente o mesmo resultado:
    export async function fetchUser(): Promise {
    try {
    const tokenData = await fetchTokenData();
    const userData = await fetchUserData(tokenData);
    return userData;
    } catch (error) {
    console.log(typeof error);
    console.log(error);
    throw error;
    }
    }

    • @tenazatto
      @tenazatto 5 месяцев назад

      Pra esse contexto de função única realmente seria mais simples dessa forma e o pattern seria uma espécie de "overengineering". Mas em um contexto maior essa exceção seria considerada genérica e provavelmente estaria espalhada em múltiplos pontos do código, o que dificulta a leitura.
      Esses padrões são sempre dependentes de contexto, dívidas técnicas e compromissos. Se o time consegue lidar bem com esse padrão, não há problema nenhum em manter. Do contrário, é melhor generalizar aos poucos certas partes para evitar ruídos na interpretação.

    • @franciscopessoa655
      @franciscopessoa655 5 месяцев назад

      Não, é uma péssima idéia você tratar vários tipos de diferentes erros em um único try/catch

    • @pedrolucasdeoliveiralara8199
      @pedrolucasdeoliveiralara8199 5 месяцев назад

      @@franciscopessoa655 no vídeo ele trata vários erros diferentes num único corpo de função, não tem diferença alguma

    • @pedrolucasdeoliveiralara8199
      @pedrolucasdeoliveiralara8199 5 месяцев назад

      @@tenazatto No Pattern apresentado também estaria espalhado em múltiplos pontos do código, não entendi seu ponto

    • @MordyDeep
      @MordyDeep 5 месяцев назад

      @@pedrolucasdeoliveiralara8199 galera complica o simples KKK eu racho de rir

  • @zagannnn
    @zagannnn 5 месяцев назад

    como configurar o mypy / linter decentemente? sei lá o que mais você falou

  • @yurisilva9029
    @yurisilva9029 5 месяцев назад

    Putz mas aí usando assim, é ruim mesmo. Agora se souber usar, vc padroniza o erro, deixa mais rastreável, evita quebrar a API exceto quando é necessário, e sem 'mascarar' os erros também. Como dizia o grande poeta, "modéstia a parte, código ruim, eu sei fazer muito bem, em em qualquer linguagem, e com qualquer paradigma..."

  • @rcrdrobson
    @rcrdrobson 5 месяцев назад

    Tu é da banda de Recife (vi postando q tá morando na itália) ? Essa coral aí no braço...

  • @uesleipedrorangel7136
    @uesleipedrorangel7136 5 месяцев назад +4

    A desculpa é que trabalha cansado? kkk
    Foi mal, desce não.
    Se você precisa de uma linguagem para não "te deixar mentir", como você disse, o problema é com você.
    De toda maneira, se você programa porcamente, seu código será ruim, independente da linguagem.
    Como resolve isso? Escrevendo testes bem feitos. Isso, sim, vai pegar todos os erros e não deixar você subir código mal escrito para produção.

  • @profano9201
    @profano9201 5 месяцев назад

    Na minha opinião a linguagem que melhor lida com esse problema é Rust usando Result pattern + Match pattern

  • @farchanjo
    @farchanjo 22 дня назад

    Usar um try catch nested eu nunca vi, pelo menos com quem trabalhei. Geralmente usamos apenas 1 try catch dentro do fluxo, nested não faz o menor sentido..

  • @lu1z00
    @lu1z00 5 месяцев назад

    A forma de try-catch em Java é da mesma forma q em python?

    • @ailuros_
      @ailuros_ 5 месяцев назад

      Fundamentalmente, sIm. Mas em Python é menos custoso e mais encorajado.

    • @lu1z00
      @lu1z00 5 месяцев назад

      @@ailuros_ a única diferença seria naquela hierarquia de erros de classes?

    • @lu1z00
      @lu1z00 5 месяцев назад

      @@ailuros_ Eu tô ligado que tem uma classe que direciona os erros pra JVM e outra que direciona os erros pro programador

  • @ellianaragao
    @ellianaragao 5 месяцев назад

    Acredito que a linha argumentativa foi meio fraca, quanto legibilidade está okay, mas apresentar apenas a ideia deste modo foi muito simplório e no fim só diz que a culpa é do programador sem indicar que existe um problema real que é a perda de performance devido utilização de exceções pra controle de fluxo

  • @felipequentino7175
    @felipequentino7175 2 месяца назад

    Acredito que você Augusto, talvez tenha se equivocado ao falar que GOTO é uma relíquia, pq no final do dia, if/else/while, todas as operações de controle de fluxo são um mero GOTO, por mais que não "codemos" usando GOTO, quando a linguagem é interpretada/compilada para assembly, o código é transformado para assembly usa os jumps na 'tradução' do código, que são os GOTO, redirecionando o fluxo do código para algum endereço x do Program Counter.
    Isso falando no nível da CPU!
    Abraços, me corrija se eu estiver errado.

  • @carlosmachado766
    @carlosmachado766 4 месяца назад

    Não é só um padrão é code smell

  • @YgorAmaral
    @YgorAmaral 5 месяцев назад

    Conteúdo interessante. Só um detalhe: Python tem tipagem forte. O fato de não precisar declarar o tipo, não torna a tipagem fraca.

  • @aristotelesfernando
    @aristotelesfernando 5 месяцев назад +2

    se try/catch é ruim, então como fica o tratamento de excessões?

  • @aostc
    @aostc 5 месяцев назад

    Porque caralhs alguém usa try catch dentro de um try catch se ocorrer um erro vai dar na mesma e seria mais fácil tratar esse erro 🤯

  • @devlan_py
    @devlan_py 5 месяцев назад

    Eu postei do vídeo, mas tenho uma dúvida um pouco fora do conteúdo, Como eu paro de ser um programado mesquinho,
    Tipo: sinto que estudo a um tempo e não tenho uma evolução

  • @lenickramone
    @lenickramone 5 месяцев назад

    Discordo q seja o try catch. Pois isso varia por linguagem. No próprio Java, que usa try catch, tb te obriga a tratar a exceção se vc chama um método q pode lançar uma exceção, vc soh escolhe se vc vai tratar ou se seu método tb vai explicitamente jogar ela pra cima

  • @RodrigoAdriano
    @RodrigoAdriano 5 месяцев назад

    Em planilhas excel com VBA usamos GOTO até hoje ;)