Pular para o conteúdo principal

Postagem em destaque

BlackTDN :: cArqTab :: Otimizando a Abertura do Sistema: Como a Escolha do Método de Carregamento Afeta o Desempenho

_Créditos da imagem: Gerada com auxílio do ChatGPT_ # cArqTab :: Como o carregamento de informações em uma variável pode tornar lenta a abertura do sistema TOTVS Microsiga Protheus --- # Comparando LoadFromDBQuery e LoadFromDBWhile: Vantagens e Desempenho No desenvolvimento de soluções para o TOTVS Microsiga Protheus, otimizar o tempo de execução das funções é essencial, especialmente quando lidamos com grandes volumes de dados. Neste artigo, vamos analisar a diferença de desempenho entre os métodos `LoadFromDBQuery` e `LoadFromDBWhile`, utilizando os tempos de execução para demonstrar a vantagem de cada abordagem. ## Contexto do Teste Para avaliar o desempenho, executamos dois procedimentos distintos: - **U_TSTArqTabLoadDBQuery**: utiliza a função `LoadFromDBQuery`. - **U_TSTArqTabLoadDBWhile**: utiliza a função `LoadFromDBWhile`. Os comandos foram executados no ambiente Cygwin, e PowerShell e os tempos foram medidos da seguinte forma: *Cygwin ```bash $ time C:/totvs/tst/sma

Protheus :: Advpl :: _SetOwnerPrvt() vs _SetNamedPrvt()

User Function TstOwnerPrvt()
    Local cProcName    := ProcName()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
        NamedOwner()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
Return( NIL )

Static Function NamedOwner()
    Local cProcName    := ProcName()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
        Owner()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
Return( NIL  ) 

Static Function Owner()
    Local cProcName    := ProcName()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
        SetOwner()
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
Return( NIL )

Static Function SetOwner()
    Local cProcName    := ProcName()
    _SetOwnerPrvt( "cOwnerVar" , "cOwnerVar_1" )
    _SetNamedPrvt( "cOwnerVar" , "cOwnerVar_N" , "NamedOwner" )
    _SetNamedPrvt( "cOwnerVar" , "cOwnerVar_T" , "U_TstOwnerPrvt" )
    ShowVar( "cOwnerVar" , cProcName , ProcLine() )
Return( NIL )

Static Function ShowVar( cVar , cProcName , nProcLine )
    IF !( Type( cVar ) == "U" )
        MsgInfo( &cVar , cProcName + " :: " + LTrim( Str( nProcLine ) ) + " :: " + cVar )
    EndIF
Return( NIL )

Adeus às PUBLIC?

[]s

иαldσ dj

Comentários

  1. Naldo,
    Não sei se entendi bem, mas então é possível mudar o escopo de uma variável já declarada ?
    Existe alguma documentação sobre a _SetOwnerPrvt() e a _SetNamedPrvt() ?

    Jefferson

    ResponderExcluir
  2. Jefferson,

    Na realidade não. Não mudamos o escopo da variável. Mas podemos definir onde ela será criada.

    _SetOwnerPrvt cria a variável uma instância acima da função que a chamou. Já _SetNamedPrvt é muito mais interessante uma vez que podemos definir em que ponto (baseado em ProcName) a variavel passará a ter visibilidade. Tanto uma quanto a outra declaram "Privates" que, a partir do ponto declarado, seja 1 "nível" ou a partir de um ponto específico terão visibilidade enquanto estiverem dentro do escopo da função. O exemplo foi provocativo de forma aguçar a curiosidade.

    Não encontrei documentação, no tdn sobre as funções.

    []s

    иαldσ dj

    ResponderExcluir
  3. Eu que vi, li e reli.. este post me perguntei da usabilidade e necessidade dessa função _SetNamedPrvt, e cheguei ao cumulo de falar que ela nunca me seria útil... Pois bem, me vejo em uma situação que somente ela resolve meu problema..
    Lição: Nunca diga nunca, ops.. (chavão)
    Reveja seus conceitos...
    Abs,

    ResponderExcluir
  4. Limitado...

    /*(
    Devido a limitações impostas ou nao visualizadas pela TOTVS
    surge um monstro, visualmente feio, porem de uma bondade sem igual.
    Este monstro é capaz de fazer coisas boas, mesmo que você o julgue
    a primeira vista como seu inimigo, ele é seu amigo e aliado, o tempo lhe mostrará...
    A necessidade de criação de um monstro surgiu diante de uma necessidade e a uma
    vasta pesquisa de um aprendiz do Dr. N.Frankstein que prega a inexistencia de limites,
    mesmo que os olhos e a racionalidade se rendam ao limite.
    )*/

    ...Nunca mais!

    _SetNamedPrvt em rotina de CNAB #Rulez

    ResponderExcluir
  5. Obrigado pelo exemplo, Naldo! Ajudou-me a compreender o funcionamento de ambas as funções, caso eu precise utilizá-las um dia. Sucesso!

    ResponderExcluir

Postar um comentário

Postagens mais visitadas