E se o compilador jogasse um warning quando estamos usando algo que claramente tem undefined behavior (como alguns casos tabelados) ?<div><br></div><div>Seria o melhor dos dois mundos: ou o programador sabe com certeza o que esta fazendo ou o compilador/interpretador/etc avisa &quot;hum... danadinho...&quot;<br>

<br><div class="gmail_quote">2011/2/14 Blabos de Blebe <span dir="ltr">&lt;<a href="mailto:blabos@gmail.com">blabos@gmail.com</a>&gt;</span><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div class="im">&gt;&gt; Enfim, o que quero dizer é que o Perl tem um imenso potencial de produzir<br>
&gt;&gt; código cheio de Pseudo-undefined Behavior; por que ninguém tem obrigação de<br>
&gt;&gt; saber todas as faces de todos os operadores; isso sem contar as L&lt;perlvar&gt;.<br>
<br>
</div>Este email também tem potencial pra produzir undefined behavior.<br>
Deveríamos parar de escrever emails por causa disso?<br>
<br>
Opa, espere um momento. Como assim um programador não deve saber<br>
exatamente o que ele está usando?<br>
<br>
É claro que o programador *tem* sim que conhecer exatamente como<br>
funciona cada token que ele está usando, senão é melhor ir vender água<br>
de coco na praia.<br>
<br>
É por isso que certas empresas abrem certas falhas de segurança em<br>
certos servidores de produção.<br>
<br>
O problema é que Perl é uma linguagem muito abrangente e concordo com<br>
vc que é praticamente impossível memorizar todos os operadores. Mas se<br>
vc *usa*, vc é obrigado a saber.<br>
<br>
O ponto aliás nem é esse. Desconhecer, não implica em undefined<br>
behavior. Implica em não obter o resultado que era esperado, logo a<br>
falha está em não ser competente o suficiente para usar esta<br>
ferramenta da linguagem.<br>
<br>
Já em C por exemplo, existem construções que *produzem* undefined<br>
behavior, ou seja fica a cargo de quem implementou o compilador<br>
resolver. Se ele quiser formatar seu disco ao atingir um ponto desses,<br>
ele é livre pra isso.<br>
<br>
Por exemplo, o padrão C não define se variáveis automáticas (alocadas<br>
na pilha) são ou não inicializadas automaticamente. Daí, num<br>
compilador do Solaris (o Fernando pode confirmar), todas as variáveis<br>
automáticas são inicializadas automaticamente (zero para inteiros). Já<br>
no gcc não (mantém-se o valor que já estava na memória). Então, você<br>
escreve um código no Solaris, compila, testa, homologa e ok. Aí você<br>
leva esse código, que está dentro do padrão, para compilar no gcc e ao<br>
rodar na nova plataforma ele quebra.<br>
<br>
Isso sim é um problema. O mesmo código, estritamente dentro do padrão,<br>
apresentando comportamentos diferentes dependendo da situação.<br>
<br>
Oras, o programador experiente tem que conhecer bem a linguagem pra<br>
não cair nessas armadilhas. Se não conhece, não deveria codificar<br>
*profissionalmente*.<br>
<br>
É como se eu pegasse uma faca e saísse dizendo que sou cirurgião, só<br>
porque sei cortar carne. E aí, posso fazer uma neurocirugia em você?<br>
Eu tenho potencial pra ser um ótimo cirurgião :)<br>
<br>
As pessoas tem que ter mais responsabilidade. Hoje qualquer mané que<br>
mal consegue encadear uma idéia, aprende um if e um for, copia e cola<br>
Perl 3 do forum ultra hacker e sai falando que é Analista Programador.<br>
É foda viu!<br>
<br>
De qualquer forma eu acho ótimo esse debate com pontos de vistas<br>
diferentes. Ninguém é dono da verdade.<br>
<div><div></div><div class="h5"><br>
Abraços<br>
<br>
2011/2/14 Stanislaw Pusep &lt;<a href="mailto:creaktive@gmail.com">creaktive@gmail.com</a>&gt;:<br>
&gt; Aliás, o que explode o meu cérebro é a frase &quot;These rules look complicated,<br>
&gt; but usually they will do what you want.&quot;, a respeito do &quot;given/when&quot;, também<br>
&gt; em L&lt;perlsyn&gt; ;)<br>
&gt;<br>
&gt; ABS()<br>
&gt;<br>
&gt;<br>
&gt;<br>
&gt; 2011/2/14 Stanislaw Pusep &lt;<a href="mailto:creaktive@gmail.com">creaktive@gmail.com</a>&gt;<br>
&gt;&gt;<br>
&gt;&gt; Ehehe, vou tentar contextualizar a minha lembrança... Tomo como exemplo a<br>
&gt;&gt; &quot;tabela-verdade&quot; do operador ~~ (&quot;smart matching&quot;, L&lt;perlsyn&gt;):<br>
&gt;&gt;<br>
&gt;&gt;            $a      $b        Type of Match Implied    Matching Code<br>
&gt;&gt;            ======  =====     =====================    =============<br>
&gt;&gt;            Any     undef     undefined                !defined $a<br>
&gt;&gt;<br>
&gt;&gt;            Any     Object    invokes ~~ overloading on $object, or dies<br>
&gt;&gt;<br>
&gt;&gt;            Hash    CodeRef   sub truth for each key[1] !grep { !$b-&gt;($_) }<br>
&gt;&gt; keys %$a<br>
&gt;&gt;            Array   CodeRef   sub truth for each elt[1] !grep { !$b-&gt;($_) }<br>
&gt;&gt; @$a<br>
&gt;&gt;            Any     CodeRef   scalar sub truth          $b-&gt;($a)<br>
&gt;&gt;<br>
&gt;&gt;            Hash    Hash      hash keys identical (every key is found in<br>
&gt;&gt; both hashes)<br>
&gt;&gt;            Array   Hash      hash slice existence     grep { exists<br>
&gt;&gt; $b-&gt;{$_} } @$a<br>
&gt;&gt;            Regex   Hash      hash key grep            grep /$a/, keys %$b<br>
&gt;&gt;            undef   Hash      always false (undef can&#39;t be a key)<br>
&gt;&gt;            Any     Hash      hash entry existence     exists $b-&gt;{$a}<br>
&gt;&gt;<br>
&gt;&gt;            Hash    Array     hash slice existence     grep { exists<br>
&gt;&gt; $a-&gt;{$_} } @$b<br>
&gt;&gt;            Array   Array     arrays are comparable[2]<br>
&gt;&gt;            Regex   Array     array grep               grep /$a/, @$b<br>
&gt;&gt;            undef   Array     array contains undef     grep !defined, @$b<br>
&gt;&gt;            Any     Array     match against an array element[3]<br>
&gt;&gt;                                                       grep $a ~~ $_, @$b<br>
&gt;&gt;<br>
&gt;&gt;            Hash    Regex     hash key grep            grep /$b/, keys %$a<br>
&gt;&gt;            Array   Regex     array grep               grep /$b/, @$a<br>
&gt;&gt;            Any     Regex     pattern match            $a =~ /$b/<br>
&gt;&gt;<br>
&gt;&gt;            Object  Any       invokes ~~ overloading on $object, or falls<br>
&gt;&gt; back:<br>
&gt;&gt;            Any     Num       numeric equality         $a == $b<br>
&gt;&gt;            Num     numish[4] numeric equality         $a == $b<br>
&gt;&gt;            undef   Any       undefined                !defined($b)<br>
&gt;&gt;            Any     Any       string equality          $a eq $b<br>
&gt;&gt;<br>
&gt;&gt;         1 - empty hashes or arrays will match.<br>
&gt;&gt;         2 - that is, each element smart-matches the element of same index<br>
&gt;&gt; in the<br>
&gt;&gt;             other array. [3]<br>
&gt;&gt;         3 - If a circular reference is found, we fall back to referential<br>
&gt;&gt; equality.<br>
&gt;&gt;         4 - either a real number, or a string that looks like a number<br>
&gt;&gt;<br>
&gt;&gt; Olha, não sei quanto aos outros participantes da lista, mas eu<br>
&gt;&gt; simplesmente não consigo me ater a todos esses detalhes<br>
&gt;&gt; :(<br>
&gt;&gt; Então nunca uso esse operador que me confunde (PARA MIM, é um &quot;Undefined<br>
&gt;&gt; Behavior&quot;), preferindo fazer &quot;à moda antiga&quot; (última coluna). Enfim, sou<br>
&gt;&gt; desses caras que enchem qqer operação de ()&#39;s, tipo: ((($x / $y) - $z) &gt; 0).<br>
&gt;&gt; Enfim, o que quero dizer é que o Perl tem um imenso potencial de produzir<br>
&gt;&gt; código cheio de Pseudo-undefined Behavior; por que ninguém tem obrigação de<br>
&gt;&gt; saber todas as faces de todos os operadores; isso sem contar as L&lt;perlvar&gt;.<br>
&gt;&gt;<br>
&gt;&gt; ABS()<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; 2011/2/14 Blabos de Blebe &lt;<a href="mailto:blabos@gmail.com">blabos@gmail.com</a>&gt;<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Oras, isso me lembra<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; <a href="http://www.ioccc.org/1987/wall.c" target="_blank">http://www.ioccc.org/1987/wall.c</a><br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Uma coisa é você usar isso em um golf, outra é usar em código de<br>
&gt;&gt;&gt; produção.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Tem gente que empeteca o código com meia dúzia de regexp e se ahca &#39;O<br>
&gt;&gt;&gt; Hackerzão&#39;.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; A maior parte dos bugs (com os quais estou lidando agora, por<br>
&gt;&gt;&gt; exemplo), teria sido evitada se fossem respeitados os padrões mínimos<br>
&gt;&gt;&gt; de boas práticas. Coisa que qualquer estagiário *deveria* sair da<br>
&gt;&gt;&gt; escolinha sabendo.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; Abraços<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; 2011/2/14 Stanislaw Pusep &lt;<a href="mailto:creaktive@gmail.com">creaktive@gmail.com</a>&gt;:<br>
&gt;&gt;&gt; &gt; Não sei pq, mas lembrei da seguinte sintaxe, compilável em Perl:<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt; -f&gt;@+?*&lt;.-&amp;&#39;_:$#/%!<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt; ABS()<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt; 2011/2/14 Blabos de Blebe &lt;<a href="mailto:blabos@gmail.com">blabos@gmail.com</a>&gt;<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Bom dia,<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Sem querer entrar em flames, ou no mérito da discussão, que tomo<br>
&gt;&gt;&gt; &gt;&gt; apenas como exemplo.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; A thread abaixo é uma discussão que está acontecendo na principal<br>
&gt;&gt;&gt; &gt;&gt; lista de C++ brasileira, sobre undefined behavior.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; <a href="http://groups.google.com/group/ccppbrasil/browse_thread/thread/9b9a7be45917095e#" target="_blank">http://groups.google.com/group/ccppbrasil/browse_thread/thread/9b9a7be45917095e#</a><br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Notem como o Undefined behavior deste exemplo em particular pode ser<br>
&gt;&gt;&gt; &gt;&gt; resolvido com &#39;codificação elegante&#39;. Ok, o assunto era outro e foi só<br>
&gt;&gt;&gt; &gt;&gt; um exemplo rápido, mas levantou a discussão que está acontecendo até<br>
&gt;&gt;&gt; &gt;&gt; agora.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; A maioria dos &#39;Undefined Behaviors&#39; das linguagens de programação que<br>
&gt;&gt;&gt; &gt;&gt; conheço (não são muitos) são casos específicos, incomuns, bem<br>
&gt;&gt;&gt; &gt;&gt; documentados, bem avisados, normalmente abertos por &#39;depender da<br>
&gt;&gt;&gt; &gt;&gt; implementação&#39; e invocados por código porco de programadores meia-boca<br>
&gt;&gt;&gt; &gt;&gt; (não que este caso de *exemplo* seja um).<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; É claro, nenhuma linguagem é perfeita (exceto lisp), mas elas possuem<br>
&gt;&gt;&gt; &gt;&gt; especificações, mais abrangentes ou menos abrangentes. Por isso, não<br>
&gt;&gt;&gt; &gt;&gt; importa a linguagem, ou você se aprofunda e aprende, ou mais cedo ou<br>
&gt;&gt;&gt; &gt;&gt; mais tarte, vai acabar caindo em alguma dessas asrmadilhas.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Na minha opinião, C tem mais armadilhas e/ou hacks que precisam de um<br>
&gt;&gt;&gt; &gt;&gt; pouco mais de conhecimento de arquitetura de computadores para escapar<br>
&gt;&gt;&gt; &gt;&gt; do que Perl, enquanto Perl tem outros tipos de armadilhas.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Entenda armadilha aqui como &quot;algo que eu imaginava de um jeito, mas<br>
&gt;&gt;&gt; &gt;&gt; aconteceu de outro&quot;, independente da expectativa ser razoável ou não.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; O negócio é que como Perl é mais fácil de lidar do que C, você alcança<br>
&gt;&gt;&gt; &gt;&gt; as armadilhas de Perl mais cedo do que conseguiria caminhar em C para<br>
&gt;&gt;&gt; &gt;&gt; alcançar as suas, logo, Perl parece mais imprevisível.<br>
&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt; &gt;&gt; Abraços<br>
&gt;&gt;&gt; &gt;&gt; =begin disclaimer<br>
&gt;&gt;&gt; &gt;&gt;   Sao Paulo Perl Mongers: <a href="http://sao-paulo.pm.org/" target="_blank">http://sao-paulo.pm.org/</a><br>
&gt;&gt;&gt; &gt;&gt;  SaoPaulo-pm mailing list: <a href="mailto:SaoPaulo-pm@pm.org">SaoPaulo-pm@pm.org</a><br>
&gt;&gt;&gt; &gt;&gt;  L&lt;<a href="http://mail.pm.org/mailman/listinfo/saopaulo-pm" target="_blank">http://mail.pm.org/mailman/listinfo/saopaulo-pm</a>&gt;<br>
&gt;&gt;&gt; &gt;&gt; =end disclaimer<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt; =begin disclaimer<br>
&gt;&gt;&gt; &gt;   Sao Paulo Perl Mongers: <a href="http://sao-paulo.pm.org/" target="_blank">http://sao-paulo.pm.org/</a><br>
&gt;&gt;&gt; &gt;  SaoPaulo-pm mailing list: <a href="mailto:SaoPaulo-pm@pm.org">SaoPaulo-pm@pm.org</a><br>
&gt;&gt;&gt; &gt;  L&lt;<a href="http://mail.pm.org/mailman/listinfo/saopaulo-pm" target="_blank">http://mail.pm.org/mailman/listinfo/saopaulo-pm</a>&gt;<br>
&gt;&gt;&gt; &gt; =end disclaimer<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt; =begin disclaimer<br>
&gt;&gt;&gt;   Sao Paulo Perl Mongers: <a href="http://sao-paulo.pm.org/" target="_blank">http://sao-paulo.pm.org/</a><br>
&gt;&gt;&gt;  SaoPaulo-pm mailing list: <a href="mailto:SaoPaulo-pm@pm.org">SaoPaulo-pm@pm.org</a><br>
&gt;&gt;&gt;  L&lt;<a href="http://mail.pm.org/mailman/listinfo/saopaulo-pm" target="_blank">http://mail.pm.org/mailman/listinfo/saopaulo-pm</a>&gt;<br>
&gt;&gt;&gt; =end disclaimer<br>
&gt;&gt;<br>
&gt;<br>
&gt;<br>
&gt; =begin disclaimer<br>
&gt;   Sao Paulo Perl Mongers: <a href="http://sao-paulo.pm.org/" target="_blank">http://sao-paulo.pm.org/</a><br>
&gt;  SaoPaulo-pm mailing list: <a href="mailto:SaoPaulo-pm@pm.org">SaoPaulo-pm@pm.org</a><br>
&gt;  L&lt;<a href="http://mail.pm.org/mailman/listinfo/saopaulo-pm" target="_blank">http://mail.pm.org/mailman/listinfo/saopaulo-pm</a>&gt;<br>
&gt; =end disclaimer<br>
&gt;<br>
&gt;<br>
=begin disclaimer<br>
   Sao Paulo Perl Mongers: <a href="http://sao-paulo.pm.org/" target="_blank">http://sao-paulo.pm.org/</a><br>
 SaoPaulo-pm mailing list: <a href="mailto:SaoPaulo-pm@pm.org">SaoPaulo-pm@pm.org</a><br>
 L&lt;<a href="http://mail.pm.org/mailman/listinfo/saopaulo-pm" target="_blank">http://mail.pm.org/mailman/listinfo/saopaulo-pm</a>&gt;<br>
=end disclaimer<br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br>Tiago B. Peczenyj<br>Linux User #405772<br><br><a href="http://pacman.blog.br">http://pacman.blog.br</a><br>
</div>