terça-feira, 16 de abril de 2024
Aprenda a Evitar Memory Leaks no .NET com Dispose e Blocos Using
Os memory leaks são como fantasmas assombrando os
desenvolvedores de software. Eles podem se esconder silenciosamente em nossos
códigos, consumindo recursos preciosos e prejudicando o desempenho do
aplicativo. No ambiente .NET, a gestão de memória é parcialmente automatizada
pelo coletor de lixo (garbage collector), mas mesmo assim, é responsabilidade
do desenvolvedor garantir a liberação adequada de recursos não gerenciados.
Felizmente, o .NET oferece algumas ferramentas poderosas para lidar com isso, como
o método Dispose() e os blocos using.
O Que São Memory Leaks?
Um memory leak ocorre quando um programa aloca memória
dinamicamente repetidamente, mas não libera essa memória quando não é mais
necessária. Isso pode acontecer por várias razões, mas é especialmente comum
quando trabalhamos com recursos não gerenciados, como arquivos, conexões de
banco de dados e objetos COM.
A Importância do Método Dispose()
O método Dispose() é uma parte fundamental do padrão
de design "Dispose pattern" no .NET. Ele é usado para liberar
explicitamente os recursos não gerenciados usados por um objeto. Ao implementar
a interface IDisposable e chamar o método Dispose(), os
desenvolvedores podem garantir que os recursos sejam liberados assim que não
forem mais necessários.
Usando Blocos Using para Garantir a Liberação de Recursos
Os blocos using no C# fornecem uma maneira
conveniente de garantir que os objetos que implementam IDisposable sejam
liberados corretamente, mesmo se ocorrerem exceções no código. Um bloco using
garante que o método Dispose() seja chamado automaticamente quando o
escopo do bloco é concluído.
Exemplo Prático
Vamos examinar um trecho de código e explorar como podemos
melhorá-lo para garantir uma gestão mais robusta de recursos no ambiente .NET.
No código acima, estamos lidando com uma operação de leitura
de dados de um banco SQLite e exibindo-os em um DataGridView. Pode ser
que vocês já estejas familiarizado com códificação
parecida. No entanto, há alguns problemas de gestão de recursos que precisamos
resolver:
1. Gestão de Conexão com o Banco de Dados
O objeto SQLiteConnection precisa ser aberto e
fechado corretamente para evitar vazamentos de recursos. Vamos usar um bloco using
para garantir que a conexão seja fechada automaticamente quando não for mais
necessária.
2. Limpeza de Recursos em Caso de Exceção
Se ocorrer uma exceção durante a execução do código dentro
do bloco using, precisamos garantir que os recursos sejam liberados
corretamente. Vamos mover a definição do objeto DataTable para dentro do
bloco using e usar o método Dispose() para liberar o leitor e o
comando em caso de exceção.
Conclusão
Lidar com memory leaks no .NET é crucial para manter a
estabilidade e o desempenho dos aplicativos. Utilizar corretamente o método Dispose()
e os blocos using é uma prática recomendada para garantir a liberação
adequada de recursos não gerenciados. Ao melhorar a gestão de recursos em nosso
código, garantimos que ele seja mais robusto, eficiente e menos propenso a
problemas como memory leaks. Utilizando blocos using para objetos que
implementam IDisposable, lidamos adequadamente com a liberação de
recursos. Ao seguir essas práticas, podemos criar aplicativos mais estáveis e
de alta qualidade no ambiente .NET. Adotar essas práticas desde o início do
desenvolvimento, os desenvolvedores podem evitar muitas dores de cabeça no
futuro e garantir uma experiência de usuário mais suave.
terça-feira, 3 de outubro de 2023
Como Alterar a Senha do Super Administrador (sa) via Prompt?
Problema:
Você se depara com uma situação em que precisa acessar o super administrador 'sa' em seu servidor SQL Server, mas não se lembra da senha. Isso pode acontecer devido a vários motivos, como esquecimento da senha ou herança de um sistema existente, onde a senha 'sa' não é conhecida. Sem acesso à conta 'sa', você não pode executar tarefas essenciais de administração de banco de dados.
Causa:
A causa raiz desse problema geralmente é o esquecimento da senha do usuário 'sa'. A conta 'sa' é altamente privilegiada e é recomendado que sua senha seja protegida com segurança. Portanto, quando essa senha é perdida ou esquecida, é necessário encontrar uma maneira de redefini-la.Solução Passo a Passo:
Aqui estão os passos para resolver esse problema e alterar a senha do super administrador 'sa' usando o prompt de comando:
Passo 1: Abra o Prompt de Comando como Administrador:
Para começar, clique com o botão direito do mouse no ícone do Prompt de Comando e selecione "Executar como administrador". Certifique-se de ter privilégios administrativos no servidor SQL.
Passo 2: Navegue até a Pasta do SQL Server:
Use o comando `cd` para navegar até o diretório onde o utilitário `sqlcmd` está localizado. Normalmente, o caminho padrão é `C:\Program Files\Microsoft SQL Server\<Versão>\Tools\Binn`. Certifique-se de substituir `<Versão>` pela versão específica do SQL Server instalada no seu sistema.
Passo 3: Execute o Comando SQL para Alterar a Senha:
Digite o seguinte comando e pressione Enter para abrir o utilitário `sqlcmd`, conectando-se ao SQL Server usando a autenticação do Windows:
sqlcmd -S localhost -E
Agora, você deve estar conectado ao SQL Server.
Passo 4: Redefina a Senha do 'sa':
Use o seguinte comando SQL para alterar a senha do super administrador 'sa'. Substitua `<nova_senha>` pela senha desejada:
ALTER LOGIN sa WITH PASSWORD = '<nova_senha>';
GO
Após executar este comando, você verá uma mensagem indicando que a senha foi alterada com sucesso.
Passo 5: Feche o Utilitário SQL e o Prompt de Comando:
Digite QUIT
no utilitário sqlcmd
para sair dele. Em seguida, feche o Prompt de Comando.
Ao seguir este guia passo a passo, você pode resolver com sucesso o problema de alteração da senha do super administrador 'sa' via prompt de comando. Lembre-se de que o usuário 'sa' possui privilégios significativos, portanto, mantenha a nova senha segura e siga as melhores práticas de segurança para proteger seu servidor SQL contra ameaças.
Agora, com acesso restabelecido ao super administrador 'sa', você pode continuar a administrar e manter seu servidor SQL Server com confiança. Espera ter ajudado, se você tiver alguma dúvida ou precisar de assistência adicional, não hesite em entrar em contato.
sexta-feira, 30 de junho de 2023
Entendendo o Conceito de Multithreading e seus Desafios
O conceito de multithreading é fundamental para compreender como os processos são executados em um sistema operacional. Neste artigo, vamos explorar o significado de "thread" e "multithreading", discutir sua relevância para os programadores e abordar os benefícios e desafios associados a esse conceito.
O que são threads:
Uma thread, também conhecida como fio ou linha, é um componente de um processo capaz de executar determinadas tarefas. Pode ser considerada como um subsistema ou um subconjunto do processo. Esse conceito pode ser comparado aos famosos "textões" do Twitter, nos quais um conteúdo extenso é dividido em partes menores para facilitar a leitura e compreensão.
Contextualizando os microprocessadores:
No contexto dos microprocessadores, o termo "thread" refere-se à capacidade de encadeamento de instruções que podem ser executadas simultaneamente. Esse conceito é complexo, mas ao longo deste artigo, procuraremos torná-lo mais compreensível para os programadores.
A importância do multithreading para os programadores:
O multithreading desempenha um papel crucial na programação, e é essencial que os desenvolvedores compreendam seus fundamentos. Neste artigo, abordaremos por que os programadores precisam conhecer o multithreading e como ele pode melhorar a eficiência e a capacidade de resposta de seus programas.
Benefícios do multithreading:
O uso de threads oferece vantagens significativas, como uma maior capacidade de resposta, compartilhamento e utilização eficiente de recursos, além de economia de tempo no desenvolvimento e gerenciamento de programas. Exploraremos cada um desses benefícios em detalhes.
Desafios e problemas do multithreading:
No entanto, o multithreading também apresenta desafios. Um dos principais problemas é o cancelamento prematuro de uma thread, o que pode interferir no funcionamento correto de outras threads. Além disso, o compartilhamento de recursos entre threads pode levar a problemas de concorrência e sincronização. Discutiremos esses desafios e como os programadores podem lidar com eles.
Concorrência versus paralelismo:
É importante distinguir entre os conceitos de concorrência e paralelismo. A concorrência envolve lidar com várias tarefas ao mesmo tempo, enquanto o paralelismo refere-se à execução simultânea de várias tarefas. Explicaremos a diferença entre esses dois conceitos e como eles se relacionam com o multithreading.
Considerações finais:
Neste artigo, exploramos o conceito de multithreading, seu significado e importância para os programadores. Discutimos os benefícios e desafios associados a esse conceito, enfatizando a necessidade de compreender a concorrência, o compartilhamento de recursos e a sincronização entre threads. Ao dominar o multithreading, os programadores podem otimizar a eficiência de seus programas e melhorar a experiência do usuário.
Lembre-se de que o multithreading é uma área complexa, mas espero que essa postagem tenha proporcionado uma compreensão básica e um ponto de partida.
.
quarta-feira, 18 de maio de 2022
Como obter a PublicKeyToken de uma biblioteca ou assembly?
Olá pessoal, hoje quero te ajudar a encontrar a PublicKeyToken ou Token de Chave Pública de um aplicativo, assembly ou dll através da linha de comando do power shall.O que é PublicKeyToken?
Vamos a prática
([system.reflection.assembly]::loadfile("C:\projects\demo20\Intelligencia.UrlRewriter.dll")).FullName
Intelligencia.UrlRewriter, Version=2.0.0.9, Culture=neutral, PublicKeyToken=0573f3650687980d
Bonús - Como obter a PublicKeyToken via código C#?
segunda-feira, 5 de agosto de 2019
Entenda o DOM de uma vez por todas - 1 Introdução
Olá, este poste é o inicio de uma série de postes com um único objecto: "Te ajudar de uma vez por todas à entender o DOM usando javascript". Então bem-vindo a primeira parte:
Introdução ao DOM
Quase sempre que um site realiza uma ação, como alternar entre uma apresentação de slides de imagens, exibir um erro quando um usuário tenta enviar um formulário incompleto ou alternar um menu de navegação, ele é o resultado do JavaScript acessando e manipulando o DOM. Neste artigo, aprenderemos o que é o DOM, como trabalhar com o documentobjeto e a diferença entre o código-fonte HTML e o DOM.
O que eu preciso?
Para entender efetivamente o DOM e como ele se relaciona com o trabalho com a Web, é necessário ter um conhecimento existente de HTML e CSS . Também é benéfico ter familiaridade com a sintaxe e a estrutura de código fundamentais do JavaScript.O que é o DOM?
No nível mais básico, um site consiste em um documento HTML. O navegador que você usa para visualizar o site é um programa que interpreta HTML e CSS e renderiza o estilo, conteúdo e estrutura na página que você vê.Além de analisar o estilo e a estrutura do HTML e do CSS, o navegador cria uma representação do documento conhecido como Document Object Model. Este modelo permite que o JavaScript acesse o conteúdo de texto e os elementos do documento do site como objetos.
JavaScript é uma linguagem interativa e é mais fácil entender novos conceitos fazendo. Vamos criar um site muito básico. Crie um index.htmlarquivo e salve-o em um novo diretório de projeto.
Para nossos objetivos, usaremos o navegador Google Chrome, mas você poderá receber resultados semelhantes de outros navegadores modernos. No Chrome, abra-se index.html. Você verá um site simples com nosso título dizendo "Document Object Model (DOM)". Clique com o botão direito em qualquer lugar da página e selecione "Inspecionar". Isso abrirá as Ferramentas do desenvolvedor.
Na guia Elements , você verá o DOM.
Nesse caso, quando expandido, parece exatamente o mesmo que o código-fonte HTML que acabamos de escrever - um tipo de documento e as poucas outras tags HTML que adicionamos. Passar o mouse sobre cada elemento destacará o respectivo elemento no site renderizado. Pequenas setas à esquerda dos elementos HTML permitem alternar a exibição de elementos aninhados.
O document object
O document oject é um objeto interno que possui muitas propriedades e métodos que podemos usar para acessar e modificar sites. Para entender como trabalhar com o DOM, você deve entender como os objetos funcionam em JavaScript.Em Developer Tools no index.html , vá para a guia Console . Digite
document
no console e pressione ENTER
. Você verá que o resultado é o mesmo que você vê na guia Elements.
Digitar document e trabalhar diretamente no console não é algo que você geralmente fará fora da depuração, mas ajuda a solidificar exatamente o que o document object é e como modificá-lo, como descobriremos a seguir.
Qual é a diferença entre o código-fonte DOM e HTML?
Atualmente, com este exemplo, parece que o código-fonte HTML e o DOM são exatamente a mesma coisa. Existem duas instâncias em que o DOM gerado pelo navegador será diferente do código-fonte HTML:- O DOM é modificado pelo JavaScript do lado do cliente
- O navegador corrige automaticamente erros no código-fonte
O console responderá com esta saída:
Document
é um objeto, body
é uma propriedade desse objeto que acessamos com notação de ponto. O envio document.body para o console gera o elemento body e tudo dentro dele.No console, podemos alterar algumas das propriedades ativas do objeto body neste site. Vamos editar o atributo style, mudando a cor de fundo para blue. Digite isso no console:
Depois de digitar e enviar o código acima, você verá a atualização ao vivo para o site, conforme a cor do plano de fundo é alterada.
Alternando para a guia Elements ou digitando document.body no console novamente, você verá que o DOM foi alterado.
backgroundColor
. Qualquer propriedade CSS hifenizada será escrita em camelCase em JavaScript
O código JavaScript que digitamos, atribuindo à cor azul como fundo do body, é agora uma parte do DOM.
No entanto, clique com o botão direito do mouse na página e selecione "Ver fonte da página". Você notará que a fonte do site não contém o novo atributo de estilo que adicionamos via JavaScript. O código-fonte ou de origem de um site não será alterada e nunca será afetada pelo JavaScript do lado do cliente. Se você atualizar a página, o novo código que adicionamos no console desaparecerá.
A outra instância em que o DOM pode ter uma saída diferente do código-fonte HTML é quando há erros no código-fonte. Um exemplo comum disso é a tag table – uma tag tbody é necessária dentro de um table, mas os desenvolvedores geralmente não a incluem em seu HTML. O navegador corrigirá automaticamente o erro e adicionará o tbody, modificando o DOM. O DOM também corrigirá tags que não foram fechadas.
O que aprendemos?
Nesta parte, definimos o DOM, acessamos o objeto document, usamos JavaScript e o console para atualizar uma propriedade do objeto document e examinamos a diferença entre o código-fonte HTML e o DOM.No próximo artigo, revisaremos a terminologia HTML importante, aprenderemos sobre a árvore DOM, descobriremos o que são nós, aprenderemos sobre os tipos mais comuns de nós e começaremos a criar scripts interativos com JavaScript.
Fique atento ao proximo artigo desta série!
Forte abraço.
terça-feira, 2 de julho de 2019
Como ignorar a acentuação ao consultar dados no Sql Server?
Vou ser rápido. Mas esse problema ocorre porque a muitas vezes a colecção do Sql Server definida é a Accent Sensitive (AS), por isso ele procurará a expressão exacta, incluindo as acentos.Solução
SELECT * FROM Produto WHERE Nome like '%pao%' COLLATE Latin1_general_CI_AI
Na consulta acima a expressão Latin1_general_CI_AIpode ser dividido nas seguintes partes:
- Latin1 - faz o servidor tratar strings usando charset latin 1, ou seja, o ascii.
- CI - especifica maiúsculas e minúsculas, portanto, "ABC" é igual a "abc".
- AI - especifica insensível à acentuação, então "ãó" é igual a "ao".
quinta-feira, 30 de maio de 2019
Como humanizar o formato dos DateTime em C#
O Algoritmo
Como usar?
quinta-feira, 25 de abril de 2019
Como gerar sequências numéricas em SQL numa consulta ou select?
Sem muitas voltas, te digo: Use a função Row_Number() do Sql Server.Confira no exemplo a seguir.
Select Row_Number() Over(Order By idAluno) as Ordem, idAluno, NomeAluno
From Aluno
Where idTurma = 2
Resultado:
Isso é tudo, apenas olhe para essa instrução como um modelo para o que realmente desejas, ou comente o para eu te ajudar.
quinta-feira, 11 de abril de 2019
Porque Sql Server está consumindo muita memória? [Resolvido]
Porque o Sql Server está consumindo muita memória?
A Solução é limitar a memória máxima do Sql Server.
- Clique com o botão direito no servidor conectado;
- Em seguida, clique em Properties (Propriedades);
- Selecione a aba Memory (Memória);
- Edite o campo Maximum Server Memory (Memória máxima do servidor). No nosso exemplo, queremos que o Sql Server consuma apenas 6GB;
- Clique em Ok para confirmar as alteração.
Bonus: Como limitar a memória do SqlServer via código?
Alguma dúvida? Deixe nos cometário. Espero ter ajudado.
segunda-feira, 28 de janeiro de 2019
Como colocar mensagem no DataList quanto está Vazio (Empty) no asp.net?
Como colocar a mensagem no DataList quanto está Vazio ou Empty conforme se faz no GridView do Asp.net?
O GridView possui a propriedade EmptyDataText que serva para colocar a mensagem de erro ou "not find" mas infelizmente o DataList e o ListView não têm esse propriedade. Para resolver este problema siga a solução abaixo:
<asp:DataList ID="dlFunc" runat="server" RepeatColumns="4">
<ItemStyle CssClass="CardSeparation" />
<ItemTemplate>
<%-- area para campos --%>
</ItemTemplate>
<FooterTemplate>
<asp:Label Visible='<%#bool.Parse((dlFunc.Items.Count==0).ToString())%>'
runat="server" ID="lblNoRecord" Text="Documento não encontrado!"></asp:Label>
</FooterTemplate>
</asp:DataList>
Isso está criando uma lable no rodapé de DataList e torná-lo visível somente se a contagem de registro DataList é 0.
<asp:Label Visible='<%#bool.Parse((dlFunc.Items.Count==0).ToString())%>'
runat="server" ID="lblNoRecord" Text="Documento não encontrado!">
Espero ter te ajudado. Um forte abraço!
segunda-feira, 21 de janeiro de 2019
Entity Framework - Como listar tabela dinamicamente através do seu nome?
public IQueryable GetMyTable(string tipo)
{
MyDbContext context = new MyDbContext();
Type type = Type.GetType($"teu_namespace.{tipo}");
if (type != null)
return context.Set(type).AsQueryable();
return null;
}
O segredo todo está no método Set. Muitas pessoas que encontram esse problema usaram esse método de maneira errada, colocando o Set<Type>. Isso sempre gerá o erro: "is a type but used as a class".
Para evitar esse problema use o Set(string) é a melhor forma para dinamizar o teu código.
Pesquisar neste blogue
Páginas
Aprenda a Evitar Memory Leaks no .NET com Dispose e Blocos Using
Os memory leaks são como fantasmas assombrando os desenvolvedores de software. Eles podem se esconder silenciosamente em nossos códigos, con...