Você está perdendo oportunidades de negociação:
- Aplicativos de negociação gratuitos
- 8 000+ sinais para cópia
- Notícias econômicas para análise dos mercados financeiros
Registro
Login
Você concorda com a política do site e com os termos de uso
Se você não tem uma conta, por favor registre-se
tenho acompanhado isto, mas não tenho um entendimento claro do que exatamente é que você quer realizar.
Costumo recodificar as coisas fazendo-as de maneiras diferentes para chegar ao resultado final que eu estava procurando, as coisas podem ser feitas de muitas maneiras.
tenho acompanhado isto, mas não tenho um entendimento claro do que exatamente é que você quer realizar.
Costumo recodificar as coisas fazendo-as de maneiras diferentes para chegar ao resultado final que eu estava procurando, as coisas podem ser feitas de muitas maneiras.
Sei exatamente o que você quer dizer: tenho centenas, algumas vezes até milhares de linhas em um bloco de código para chegar ao que eu preciso.
você tem que amar o que você faz.
Obrigado Marco. Claro que as coisas podem ser feitas de muitas maneiras (e soluções), às vezes você tem que escolher uma delas para atingir seu objetivo, mas há algumas maneiras mais fáceis do que outras. Neste caso, a alternativa que eu tomei para imitar a função: StringToEnum estava usando múltiplas comparações de string com "se", mas como eu disse antes da função eval (não implementada em mql5) poderia ajudar a evitar todos aqueles "se", e também ajudar na manutenção porque se constantes mudam o nome deles, então você não tem que mudar o bloco de "se".
Você pode explicar, por favor, por que você precisa deste StringToEnum. Obviamente você tem uma corda com um valor enumeral, mas por que ela está em uma corda? Estou curioso para saber.
Em outras palavras, com o apoio da função eval(...) poderíamos resolver muitas coisas ao mesmo tempo.
Isso NUNCA vai acontecer, não perca seu tempo com isso. A função Eval() é uma porta aberta para vazamento de segurança, Metaquotes não adicionarão tal função.
Sei exatamente o que você quer dizer: tenho centenas, algumas vezes até milhares de linhas em um bloco de código para chegar ao que preciso.
você tem que amar o que você faz.
Seu problema NÃO pode ser resolvido com um StringToEnum(), você já o sabe (eu acho).
Correto, mas isso pode ser feito ao contrário.
Mas não faria sentido, pois MODE_SMMA já tem valor inteiro 2 e é por isso que escrevi que não entendo o que o cyberglassed está tentando realizar.
Correto, mas isso pode ser feito ao contrário.
Mas não faria sentido, pois MODE_SMMA já tem valor inteiro 2 e é por isso que escrevi que não entendo o que o cyberglassed está tentando realizar.
Marco a alternativa que uso é algo como o seguinte (versão muito minimalista):
é claro que eu não começo da constante, eu começo de um fio, eu digo isto porque em seu código você escreveu o seguinte:
como se você tivesse desde o início a própria constante.
Desculpe se eu o entendi mal, meu inglês não é muito bom.
Cumprimentos.
Você pode explicar, por favor, por que você precisa deste StringToEnum. Obviamente você tem uma corda com um valor enumeral, mas por que ela está em uma corda? Estou curioso para saber.
Em outras palavras, com o apoio da função eval(...) poderíamos resolver muitas coisas ao mesmo tempo.
Oi Alain, eu satisfaço sua curiosidade :P
Imagine que você está usando múltiplos códigos mql5 externos, então você está lidando com múltiplos tipos de dados "enum" definidos neles, e é claro, como um humano, é melhor que você se lembre do nome da string de cada valor de cada "enum". Então, em alguma parte você quer especificar algum valor de algum enum em formato de string, então você não pode fazê-lo diretamente, então você tem que usar algum trabalho como eu escrevi acima. Isto tem duas grandes desvantagens a primeira é que você tem que coletar todos os valores de todos os enumeros envolvidos e a segunda desvantagem é a manutenção, então se você atualizar algum código mql5 externo onde o desenvolvedor mudou o valor int associado a alguma representação constante, então você pode ter um comportamento inesperado, então você tem que continuar inspecionando por atualizações no código.
Sobre o tópico vazamento de segurança... Não estou totalmente de acordo com o que você disse sobre o assunto é uma porta aberta para o vazamento de segurança. Claro que poderia ser uma porta aberta, mas você como programador tem que definir os limites e cuidar de possíveis situações críticas, quero dizer que você pode gerenciar perfeitamente tais situações como em PHP, mesmo em SQL com injeção de código onde você tem que analisar alguns dados críticos possíveis de entrada dos usuários caso eles tenham acesso ao seu código.
Talvez no futuro tenhamos pouca sorte e a equipe de desenvolvedores possa nos dar alguma ajuda nessa direção, então, por enquanto, podemos usar soluções de trabalho :P
Marco a alternativa que uso é algo como o seguinte (versão muito minimalista):
é claro que eu não começo da constante, eu começo de um fio, eu digo isto porque em seu código você escreveu o seguinte:
como se você tivesse desde o início a própria constante.
Desculpe se eu o entendi mal, meu inglês não é muito bom.
Cumprimentos.
É por isso que é chamado ao contrário e você começa comparando todas as enumerações para dissolver o valor da enumeração a partir da corda.
Mas isso não é a mesma coisa?
não importa de que lado você compara a picada se houver uma correspondência, ela assinará o valor a b.
então aqui começamos com um valor de corda, mas qual é a diferença?
Nenhuma.
...
... mas isso não é a mesma coisa?
não importa de que lado você compara o ferrão se houver uma correspondência, ele assinará o valor a b.
Então, aqui começamos com um valor de corda, mas qual é a diferença?
Nenhuma.seu código acima é inútil porque ele sempre retornará "b = 3" (último "se" porque você não está usando "senão se")
se você usar "else if", então sempre retornará "b = 0".
de qualquer forma, as informações: "b = 3" todas as vezes, não dá nenhuma informação.