Erros, bugs, perguntas - página 2209

 
Slava:

E porque os seus exemplos são puramente teóricos. São puramente para estudantes. Nenhum programador no seu perfeito juízo colocaria tais coisas em produção.

Os incrementos e decretos de prefixos e de prefixos são de facto utilizados em primeiro lugar em loops. E são chamados de incrementos e decretos!

Aqui estão alguns exemplos

и

Se reivindicar que as operações de prefixo e postfixação funcionam da mesma forma, então faça uma bandeira na mão e um tambor no pescoço.

No caso de incremento de prefixo, obterá um elemento de matriz nula não-inicializado e um erro de matriz fora do intervalo na última iteração.

Talvez a sua mente elevada não o perceba, vou repetir a minha pergunta mais uma vez.

а при чем тут array[++i]=i и array[i++]=i, как я могу сравнить то, чего не было в беседе...

O destacado é-lhe difícil de ver?

Passando agora à questão, porque é que no exemplo que aparece na conversa, o resultado em mql == 12 e não importa se foi feito à mão ou não, quando há uma diferença nas operações postfix e prefixo, o resultado deve ser == 13

ps. e eu não estou a fazer uma declaração, porque agora eu verifiquei e realmente faço postfix e prefixo agora têm uma diferença, mas a minha pergunta acima dá razões para acreditar que as ambiguidades na linguagem em tempo de compilação aparentemente suficiente e antes de você pular sobre alguém no ramo, lidar com estes UB, não estamos em falta aqui

A propósito, vejo que a ajuda já foi mexida)).

 
Konstantin:

Talvez a sua mente elevada não perceba, vou repetir a minha pergunta novamente.

não compreende a parte destacada?

Passando agora à questão, porque no exemplo, que aparece na conversa, o resultado em mql == 12 e não importa se foi feito à mão ou não, se há uma diferença nas operações postfix e prefixo, o resultado deve ser == 13

ps. e eu não estou a fazer uma declaração, porque agora eu verifiquei e realmente faço postfix e prefixo agora têm uma diferença, mas a minha pergunta acima dá razões para acreditar que as ambiguidades na linguagem em tempo de compilação aparentemente suficiente e antes de você pular sobre alguém no ramo, lidar com estes UB, não estamos em falta aqui

A propósito, a ajuda parece ter sido empurrada por aí).

Não seja ranhoso.

Quem diz que os resultados têm de ser 13? Mais uma vez, os resultados com efeitos secundários são altamente dependentes da optimização. Mesmo que não se aplique optimização a tal expressão, entra em jogo uma implementação - uma alteração no valor da variável imediatamente após a sua utilização ou após o cálculo da expressão. Qual é a implementação correcta?

Não vamos lidar com a UB, isso é indefinido, e escreveu claramente: "Não faças isso.

Onde foi copiada a ajuda? Abri a referência MQL5 do MetaEditor build 1755 datado de 18 de Janeiro. Diz a mesma coisa

Avisoimportante

int i=5;
int k = i++ + + ++i;

Podem ocorrer problemas computacionais ao mover a expressão acima de um ambiente de programação para outro (por exemplo, de Borland C++ para MQL5). Em geral, a ordem dos cálculos depende da implementação do compilador. Na prática, há duas maneiras de implementar a pós-decremento:

  1. O pós-decremento (pós-incremento) é aplicado à variável após o cálculo de toda a expressão.
  2. O pós-decremento (pós-incrementação) é aplicado à variável imediatamente na operação.

Actualmente, a primeira forma de cálculo pós-decremento é implementada na MQL5. Mas mesmo conhecendo esta peculiaridade, não se recomenda a experimentação da sua utilização.


A sua afirmação original era que não há diferença entre as operações postfix e prefixo. Não há?

 
Slava:

Não seja petulante.

Quem diz que os resultados têm de ser 13? Mais uma vez, os resultados com efeitos secundários são altamente dependentes da optimização. Mesmo que não se aplique optimização a tal expressão, entra em jogo uma implementação - uma alteração no valor da variável logo após a sua utilização ou após o cálculo da expressão. Qual é a implementação correcta?

Não vamos lidar com a UB, é por isso que é indefinida, e dissemos explicitamente "não faças isso".

Para onde foi na referência? Abri a referência MQL5 do MetaEditor build 1755 datado de 18 de Janeiro. Diz a mesma coisa

Avisoimportante

int i=5;
int k = i++ + + ++i;

Podem ocorrer problemas computacionais ao mover a expressão acima de um ambiente de programação para outro (por exemplo, de Borland C++ para MQL5). Em geral, a ordem dos cálculos depende da implementação do compilador. Na prática, há duas maneiras de implementar a pós-decremento:

  1. O pós-decremento (pós-incremento) é aplicado à variável após o cálculo de toda a expressão.
  2. O pós-decremento (pós-incrementação) é aplicado à variável imediatamente na operação.

Actualmente, a primeira forma de cálculo pós-decremento é implementada na MQL5. Mas mesmo conhecendo esta peculiaridade, não se recomenda a experimentação da sua utilização.


A sua afirmação original era que não há diferença entre as operações postfix e prefixo. Não é assim?

Não estou a ser atrevido, note onde começou o diálogo, ou seja, tive de executar um código que eu nem sequer conhecia - super

quanto à ajuda - sim, foi reformulada porque quando estava a lidar (há cerca de dois anos atrás) com operações postfix e prefixos em mql, obviamente não me lembro agora deste material

portanto, o assunto foi encerrado, e introduzimos esta diferença e fizemo-lo bem, mas é preciso avisá-los de que se está a mudar

[Excluído]  
. ... Rick D. ... .:
Aconselhar sobre fecho parcial de posição, tipo de conta RETAIL_HEDGING. Por exemplo, fecho metade de uma posição no Expert Advisor e uma nova encomenda com um lote mais pequeno deve abrir automaticamente. Então, em que altura é garantido que a nova encomenda está no terminal? Compreendo correctamente que não tem de aparecer imediatamente após o PositionClosePartial e que temos de o apanhar algures na OnTrade?
Deixem-me tentar responder à minha própria pergunta. Ao chamar o PositionClosePartial, o bilhete de uma ordem fechada voltará ao CTrade::ResultOrder(), e o bilhete de posição permanece o mesmo, mas a posição em si terá um lote menor. Vamos tentar concluir que a chamada de PositionClosePartial leva a uma diminuição síncrona da posição e alteração do histórico da ordem numa única transacção.
 

Que diabos é isso?

2018.05.15 12:50:04.594 Pred_Find (GBPUSD,M1)   Access violation at 0x000000013F1C4945 read to 0xFFFFFFFFFFFFFFFF
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48A0 48895 C2418        mov        [rsp+0x18], rbx
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48A5 48897 C2420        mov        [rsp+0x20], rdi
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48AA 4156              push       r14
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48AC 4883 EC20          sub        rsp, 0x20
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48B0 488 BDA            mov        rbx, rdx
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48B3 4 C8BF1            mov        r14, rcx
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48B6 4883 FA20          cmp        rdx, 0x20
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48BA 7307              jae        0x13f1c48c3
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48BC BB20000000        mov        ebx, 0x20
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48C1 EB13              jmp        0x13f1c48d6
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48C3 488 BCB            mov        rcx, rbx
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48C6 83 E107            and        ecx, 0x7
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48C9 740 B              jz         0x13f1c48d6
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48CB B808000000        mov        eax, 0x8
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48D0 482 BC1            sub        rax, rcx
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48D3 4803 D8            add        rbx, rax
2018.05.15 12:50:04.661 Pred_Find (GBPUSD,M1)                 000000013 F1C48D6 498 B4620          mov        rax, [r14+0x20]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48DA 33 FF              xor        edi, edi
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48DC 4885 C0            test       rax, rax
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48DF 0 F8485000000      jz         dword 0x13f1c496a
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48E5 483 B58F8          cmp        rbx, [rax-0x8]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48E9 7616              jbe        0x13f1c4901
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48EB 488 B5008          mov        rdx, [rax+0x8]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48EF 33 C0              xor        eax, eax
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48F1 0 FB6CA            movzx      ecx, dl
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48F4 4883 E2FC          and        rdx, 0xfc
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48F8 80 E102            and        cl, 0x2
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48FB 480 F44C2          cmovz      rax, rdx
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C48FF EB0E              jmp        0x13f1c490f
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4901 488 BF8            mov        rdi, rax
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4904 488 B00            mov        rax, [rax]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4907 A802              test       al, 0x2
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4909 7509              jnz        0x13f1c4914
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C490B 4883 E0FC          and        rax, 0xfc
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C490F 4885 C0            test       rax, rax
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4912 75 D1              jnz        0x13f1c48e5
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4914 4885 FF            test       rdi, rdi
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4917 7451              jz         0x13f1c496a
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4919 488 BD7            mov        rdx, rdi
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C491C 498 D4E18          lea        rcx, [r14+0x18]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4920 E89B0F0000        call       0x13f1c58c0  ; #5079 (terminal64.exe)
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4925 4 C8B47F8          mov        r8, [rdi-0x8]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4929 4 C2BC3            sub        r8, rbx
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C492C 4983 F820          cmp        r8, 0x20
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4930 7224              jb         0x13f1c4956
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4932 4983 C0F8          add        r8, 0xf8
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4936 488 D5308          lea        rdx, [rbx+0x8]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C493A 4803 D7            add        rdx, rdi
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C493D 498 D4E18          lea        rcx, [r14+0x18]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4941 4 C8942F8          mov        [rdx-0x8], r8
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)      crash -->  000000013 F1C4945 4 D894410F8        mov        [r8+rdx-0x8], r8
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C494A 48895 FF8          mov        [rdi-0x8], rbx
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C494E 4 D8B4618          mov        r8, [r14+0x18]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4952 41 FF5008          call       qword near [r8+0x8]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4956 488 BC7            mov        rax, rdi
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C4959 488 B5C2440        mov        rbx, [rsp+0x40]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)                 000000013 F1C495E 488 B7C2448        mov        rdi, [rsp+0x48]
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   00: 0x000000013F1C4945
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   01: 0x000000013F63EA90
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   02: 0x00000000FFFFFFFF
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   03: 0x000000005A3CD7A0
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   04: 0x000000013F6303ED
2018.05.15 12:50:04.662 Pred_Find (GBPUSD,M1)   
 
Konstantin:

\na ajuda - sim, foi fortemente reformulada, porque quando estava a lidar (há cerca de dois anos) com operações postfix e prefixos em mql, obviamente não me lembro agora deste material

em geral, o tema foi encerrado, e introduzimos esta diferença e fizemo-lo bem, mas tem de os avisar sobre as mudanças, não é verdade?

Por uma questão de interesse, decidi verificar a antiga construção do 1159 a partir de Junho de 2015. A sua ajuda tem tudo o que Slava citou. Por isso, talvez se tenha confundido algo.

[Excluído]  
Aleksey Vyazmikin:

Que diabos é isso?

É um acidente:) Vá para Servicedesk!

 
Alexey Kozitsyn:

É um acidente:) Vá para Servicedesk!

Já está - partiu o banco :)

[Excluído]  
Aleksey Vyazmikin:

Estou a ver - partiu o banco :)

Acontece)

 
Alexey Kozitsyn:

Acontece)

Não sei como localizar este erro? Só não quero dar o guião inteiro, e não quero reembalar tudo....