Quaisquer perguntas de recém-chegados sobre MQL4 e MQL5, ajuda e discussão sobre algoritmos e códigos - página 614
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
Bem, você demonstrou que estes não são erros críticos.
Como a função funciona, você mesmo já respondeu:
No testador está tudo bem. É assim que funciona na prática.
Neste caso você precisa lidar com o código, imprimir( Imprimir(...) ) todos os valores e ver de onde vem o erro
No testador, está tudo bem. É assim que funciona na prática.
Você obteve sua resposta:
Fórum sobre comércio, sistemas automatizados de comércio e testes de estratégia comercial
Qualquer pergunta de iniciantes sobre MQL4, ajuda e discussão sobre algoritmos e códigos
Alexey Viktorov, 2018.09.06 21:00
Direção para pensar: Se o lucro for inferior a zero... qual será o tamanho da matriz durante a triagem???
E qual é o tamanho da matriz se não há nenhuma ordem???Boa tarde, a EA é chamada de "Rollover", mas não funciona como planejado. Ela dobra o lote se fechar em menos, mas o fechamento subsequente do TP por alguma razão não permite o retorno de negócios menos, que foram fechados antes. Por favor, informe o que está errado, eu não consigo descobrir. Gostaria de fazer minha pergunta na minha caixa de correio.
Eu não entendo bem o que exatamente esta função faz. Mas, como disse o autor, seu propósito é cobrir a perda de pedidos com pedidos lucrativos entre os símbolos. Eu ficaria feliz se você pudesse me ajudar a corrigir e entender a função
Você não entende, e eu não quero entender o que esta função faz. Você o usa. Você o escolheu por si mesmo. Como você pode usar algo sem entender para que serve.
Eu acabei de lhe dizer de onde vem o erro, por que razão.
Mais um esclarecimento:
Uma matriz é declarada. É destacado em verde. Tem comprimento zero na primeira dimensão. A linha em azul não é clara. Se você quiser redefinir o tamanho da matriz, existe o ArrayFree() Mas mesmo esta função será inútil, uma vez que a matriz dinâmica recém declarada tem comprimento zero.
2. Se não houver ordens, o código marcado em vermelho não será executado. Portanto, o tamanho da matriz permanecerá zero.
3. A classificação por matriz é fornecida em cada carrapato. Segue o código. E o que pode ser classificado em um bolso vazio? A menos que sejam 2 ovos de codorniz...?
E aqui está o texto de erro... O que posso dizer? Os desenvolvedores não previram que alguém pudesse tentar classificar uma matriz vazia. Eles não chegaram a uma mensagem especial para isso.
Você não entende, e eu não quero entender o que esta função faz. Você o usa. Você o escolheu por si mesmo. Como você pode usar algo sem entender para que serve.
Eu acabei de lhe dizer de onde vem o erro, por que razão.
Mais um esclarecimento:
1. uma matriz é declarada. É destacado em verde no código. Tem comprimento zero na primeira dimensão. A linha destacada em azul não é clara. Se quisermos repor o tamanho da matriz, existe o ArrayFree() , mas mesmo esta função será inútil, uma vez que a matriz dinâmica que acabamos de declarar tem comprimento zero.
2. Se não houver ordens, o código marcado em vermelho não será executado. Portanto, o tamanho da matriz permanecerá zero.
3. A classificação por matriz é fornecida em cada carrapato. Segue o código. E o que pode ser classificado em um bolso vazio? A menos que sejam 2 ovos de codorniz...?
E este é o texto do erro... O que posso dizer? Os desenvolvedores não previram que alguém pudesse tentar ordenar uma matriz vazia. Eles não chegaram a uma mensagem especial para isso.
Alexey, você está errado. ArrayFree() serve para liberar a memória da matriz quando ela não é mais necessária, o que é muito raramente necessário, e certamente não neste caso.
ZeroMemory(a), ArrayInitialize(a,xxx) deve ser usado para zerar a matriz, e ArrayResize(a,xxx) deve ser usado para redimensioná-la na primeira dimensão.
No entanto, esta emenda não afeta seu raciocínio - é correta.
Alexey, isso não é correto. ArrayFree() é usado para liberar a memória de uma matriz quando esta matriz não é mais necessária, o que é muito raro, e definitivamente não neste caso.
ZeroMemory(a), ArrayInitialize(a,xxx) deve ser usado para zerar a matriz, e ArrayResize(a,xxx) deve ser usado para redimensioná-la na primeira dimensão.
No entanto, esta emenda não afeta seu raciocínio - é correta.
De acordo com a documentação
ArrayFree .
libera o buffer de qualquer matriz dinâmica e define o tamanho da dimensão zero como 0.
De acordo com a documentação
Talvez eu não tenha me expressado corretamente e você me tenha entendido mal.E mais adiante, lá atrás:
Nota
O uso da função ArrayFree() em scripts e indicadores não é necessário muitas vezes, pois toda a memória utilizada é imediatamente liberada após o script parar de funcionar. Nos indicadores personalizados, a maioria das operações com matrizes estão acessando buffers indicadores, cujos tamanhos são automaticamente gerenciados pelo subsistema executivo do terminal do cliente.
Se um programa precisa gerenciar a memória independentemente em condições dinâmicas complexas, a função ArrayFree() permitirá liberar explicitamente e imediatamente a memória ocupada por uma matriz dinâmica desnecessária.
Libera o buffer de qualquer matriz dinâmica e define o tamanho da dimensão zero para 0
Você entendeu? Você leu a segunda parte e perdeu a primeira - importante - parte? Ele libera a memória alocada para a matriz. Foi-se... O espaço de memória alocado para a matriz é liberado e pode então ser ocupado por outros dados. Por que, cada vez que você reentrar na função, a memória deve ser reatribuída a esta matriz? Você é quem deve libertá-la. Tudo que você precisa fazer é mudar o tamanho - ArrayResize() ou zerar o array - ArrayInitialize(), ZeroMemory(). E o espaço de memória para a matriz não será liberado, e permanecerá reservado para esta matriz até que o programa seja concluído.
E depois há o mesmo:
Nota
O uso da função ArrayFree() em scripts e indicadores não é necessário com muita freqüência, pois toda a memória utilizada é liberada imediatamente após a conclusão da operação. Nos indicadores personalizados, a maioria das operações com matrizes estão acessando buffers indicadores, cujos tamanhos são gerenciados automaticamente pelo subsistema executivo do terminal do cliente.
Se um programa precisa gerenciar a memória independentemente em condições dinâmicas complexas, a função ArrayFree() permitirá liberar explicitamente e imediatamente a memória ocupada por uma matriz dinâmica desnecessária.
Libera o buffer de qualquer matriz dinâmica e define o tamanho da dimensão zero para 0
Você entendeu? Você leu a segunda parte e perdeu a primeira parte importante, não leu? Ele libera a memória alocada para a matriz. Isso é tudo... foi-se... O espaço de memória alocado para a matriz é liberado e pode ser ainda mais ocupado por outros dados. Por que, cada vez que você reentrar na função, a memória deve ser reatribuída a esta matriz? Você é quem deve libertá-la. Tudo que você precisa fazer é mudar o tamanho - ArrayResize() ou zerar o array - ArrayInitialize(), ZeroMemory(). E o espaço de memória para a matriz não será liberado, e permanecerá reservado para esta matriz até que o programa seja concluído.
Ok... E se uma matriz local for declarada a cada chamada de uma função ou, o mais improvável, a cada carrapato... Mas a memória para a matriz é alocada cada vez que a matriz é definida. Não é assim? E não importa se a memória é liberada ou não, mas a memória está sendo alocada a cada vez...
Minha idéia principal era que você não deveria fazer isso... e, se o fizer, é melhor fazê-lo através do ArrayFree().
Aqui está o que é interessante: se uma matriz local é declarada cada vez que uma função é chamada, correspondentemente, a memória é reservada para ela cada vez. Mas que endereços são usados quando se faz isso? O mesmo que ao declarar a matriz pela primeira vez, ou o que será usado?
Boa tarde, a EA é chamada de "Rollover", mas não funciona como planejado. Ela dobra o lote se fechar em menos, mas o fechamento subsequente do TP por alguma razão não permite o retorno de negócios menos, que foram fechados antes. Por favor, informe o que está errado, eu não consigo descobrir. Gostaria de agradecer antecipadamente a todos os que comentaram.
Tente verificar a duplicação mais cedo do que o lote inicial. Veja o fechamento por hora.