Библиотека шарписта | C#, F#, .NET, ASP.NET
22.9K subscribers
2.26K photos
35 videos
85 files
4.42K links
Все самое полезное для C#-разработчика в одном канале.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/b60af5a4

Для обратной связи: @proglibrary_feeedback_bot

РКН: https://gosuslugi.ru/snet/67a5c81cdc130259d5b7fead
Download Telegram
🛠 How to: как соблюдать принцип DRY

DRY (Don’t Repeat Yourself) — принцип, согласно которому каждый фрагмент знания должен существовать в системе только в одном месте. Никакого копипаста и дублирующей логики.

Проблема: дублирование валидации
// Пример плохого кода
if (user.Age < 18)
throw new Exception("User must be at least 18");

...

if (user.Age < 18)
return BadRequest("User must be at least 18");

При изменении правила — нужно помнить обновить его везде. Ловушка копипаста.

Решение: вынос логики в общее правило
public static class ValidationRules
{
public static bool IsAdult(User user) => user.Age >= 18;
}


Теперь в коде
if (!ValidationRules.IsAdult(user))
throw new Exception("User must be at least 18");

// И в другом месте:
if (!ValidationRules.IsAdult(user))
return BadRequest("User must be at least 18");


Альтернатива: использование FluentValidation или DataAnnotations
public class User
{
[Range(18, int.MaxValue, ErrorMessage = "User must be at least 18")]
public int Age { get; set; }
}


Где чаще всего нарушают DRY в .NET:


• Повторяющиеся SQL-запросы и фильтры
• Повторение одинаковых exception'ов, логов, сообщений
• Дублирование конфигурации
• UI-формы и компоненты

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍11🔥1😢1👾1
🧱 7 архитектурных паттернов, которые должен знать каждый программист

В быстро меняющемся мире разработки от программиста всё чаще требуется не просто писать код, а понимать, как правильно проектировать системы.

Архитектурные паттерны — это фундаментальные подходы, помогающие создавать масштабируемые, устойчивые и поддерживаемые решения.

В статье собрали и разобрали 7 архитектурных паттернов, которые сегодня стоит знать каждому разработчику — будь то разработка микросервисов, проектирование API или работа с распределёнными транзакциями.

➡️ Узнать паттерны

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🥱31🥰1
💻 Команда дня: сборка, которой не нужен .NET

Сегодня покажем команду, которая используется для публикации .NET-приложения, готового к развертыванию на целевой платформе (в данном случае — Linux x64):
dotnet publish -c Release -r linux-x64 --self-contained true


Расшифровка параметров

dotnet publish
Основная команда .NET CLI, предназначенная для компиляции приложения и подготовки всех необходимых файлов для его запуска.

-c Release
Указывает конфигурацию сборки. В данном случае Release означает, что будет использована конфигурация для продакшн-сборки, в отличие от Debug, где остаются отладочные символы и меньше оптимизаций.

-r linux-x64
Указывает целевую платформу. Здесь linux-x64 означает, что публикуемое приложение будет запускаться на 64-битной Linux-системе.

--self-contained true
Делает сборку самодостаточной: весь .NET Runtime и все зависимости включаются в сборку.
Это позволяет запускать приложение на машине без установленного .NET.

Это похоже на то, как если бы вы не просто упаковали ваш код, а положили его вместе с собственной версией операционной системы. Он будет работать «в вакууме», не завися от того, что есть на машине пользователя.

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍25🥱13🔥1🤩1
✏️ Промпт дня: специалист по резюме

Рынок труда меняется, а с ним — и ожидания работодателей. Сегодняшний промпт поможет вам шаг за шагом обновить или создать резюме.

Промпт:
Assist me in reviewing, completing, or creating my resume based on my profession. First, ask if I would like to specify what my profession is (to refine the resume to make it more appealing to employers). Then, ask if I would like to paste an existing resume or create a new one from scratch. If I do, ask me to paste it. You will help me identify any missing information or sections. You will ask me to provide the necessary information, step-by-step. If I do not have an existing resume or prefer to create a new one, you will guide me, step-by-step, through the process of providing the necessary information to craft an outstanding and tailored resume. Maintain a conversational approach, divide each section so it has its dedicated space in the conversation (before moving on to the next section, display the inserted information and check to make sure it's correct.) and provide expert explanations for each step.


When the resume is complete, proofread the resume and provide specific suggestions (in bullet points) to make the resume more appealing to potential employers.


💬 Поделитесь в комментариях: когда вы в последний раз обновляли своё резюме 👇

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
😁9👍2🤔1
💬 ООП вокруг нас

Наш подписчик спросил:
Где используется ООП, никак не могу понять


Многие изучают классы и объекты, но не видят, где это всё в жизни применяется. Давайте разберёмся — и на конкретных примерах.

Базовая единица ООП это объект. Объект — это экземпляр класса. Он объединяет в себе данные (поля/свойства) и логику (методы).

Пример:
class Cat
{
public string Name = "Барсик";

public void Meow()
{
Console.WriteLine("Мяу!");
}
}

// Создание объекта:
Cat cat = new Cat();
cat.iss.oneow();


Вот это — объекты в C#:

Button, Form, Label — в WinForms и WPF.
Player, Enemy, Weapon — в Unity.
User, Product, Order — в ASP.NET проектах.
HttpClient, FileStream, List<T> — в стандартной библиотеке.

У всех этих объектов есть состояние и поведение.

Это лишь часть, которая входит в понятие объектно-ориентированного программирования. Далее идут более глубокие принципы: абстракции, наследование, полиморфизм.

💬 Где вы используете ООП? Пишите свои варианты в комментариях👇

P.S. Если хотите задать вопрос сообществу, заполните
нашу гугл-форму.

🐸Библиотека шарписта #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
🥱26👍4😁4🤩1🌚1
🦾 Не наступайте на чужие грабли

В мире C# даже опытные разработчики регулярно совершают на ошибки, которые на первый взгляд безобидны, но влекут за собой трудноловимые баги, утечки ресурсов и просадки производительности.

Наткнулись на видео, в котором разбираются 10 самых распостранённых ошибок — от неоптимизированной конкатенации до страшных циклов.

➡️ Смотреть видео

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6
🕖 Почему база данных тормозит ваше приложение и как это исправить

Когда приложение начинает «тормозить», несмотря на тщательно оптимизированный код и обновлённые библиотеки, причина часто кроется не в логике приложения, а в базе данных.

Запросы к БД могут занимать секунды, превращая миллисекундные операции в узкое место производительности.

Если не решить эту проблему, API будет медленным, пользователи — недовольными, а система — нестабильной при высокой нагрузке.

➡️ Узнать как решить проблемы с БД

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
😁11👍2🥱2👾1
⚙️ CA1859: производительность или гибкость

Недавно в сабреддите C# разгорелась дискуссия вокруг предупреждения компилятора CA1859: «Используйте конкретные типы, когда это возможно, для улучшения производительности». Это подняло вечный вопрос: стоит ли жертвовать абстракцией ради скорости?

⚙️ Аргументы за использование конкретных типов:

— Конкретные типы позволяют избежать накладных расходов, связанных с виртуальными вызовами и аллокациями.

— Внутренние методы, использующие конкретные типы, могут быть проще и эффективнее, так как они не требуют обработки различных реализаций интерфейсов.

🧩 Аргументы в пользу абстракций
:

— Использование интерфейсов, таких как IEnumerable или IDictionary, позволяет методам работать с различными реализациями, повышая переиспользуемость кода.

— Абстракции облегчают написание модульных тестов, позволяя подменять зависимости мок-объектами.

💬 А что выбирает вы? Гибкость или быструю работу? Пишите свои мысли в комментарии👇

🐸Библиотека шарписта #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍81
📰 Еженедельный дайджест

Собрали для вас материалы, которые вы могли пропустить.

Почему переход с C# на F# может быть выгоден для бизнеса
Компания Ada Beat делится опытом перехода с C# на F#, отмечая, что это приводит к упрощению кода, снижению затрат на поддержку и ускорению вывода продуктов на рынок.

Extension members в C# 14
В блоге разработчиков .NET рассказали о новой фиче — extension members, расширяющей привычные extension methods. Теперь разработчики могут добавлять к существующим типам не только методы, но и свойства — как экземплярные, так и статические.

Почему стартап Tracebit выбрал C#
В блоге Microsoft CTO стартапа Tracebit, Сэм Кокс, делится причинами выбора C# для создания B2B SaaS-продукта в области безопасности.

Новый выпуск подкаста .NET Rocks
Ведущие обсудили извечный вопрос: как найти баланс между архитектурным дизайном и непосредственным написанием кода.

7 архитектурных паттернов, которые должен знать каждый программист

Почему база данных тормозит ваше приложение и как это исправить

🐸Библиотека шарписта #свежак
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🥰1😁1
В чем разница между Convert.ToString() и ToString()?

👾 — Convert.ToString() обрабатывает значения null, а ToString() — нет
👍 — ToString() выводит данные в соответствии с предоставленным форматом
🥰 — Convert.ToString() обрабатывает только значения null
⚡️ — ToString() обрабатывает значения null, а Convert.ToString() — нет

🐸Библиотека задач по C#
Please open Telegram to view this post
VIEW IN TELEGRAM
👍48👾29🌚5😁21
🤨 Подборка вакансий для шарпистов

Senior C# Developer — до 400 000 ₽, Удалёнка.

Middle Full-stack разработчик (C#/TypeScript) — от 200 000 ₽, Удалёнка.

C#/.NET-разработчик — Удалёнка (Нижний Новгород).

Backend-разработчик (.NET) — Удалёнка.

Senior Developer — до 600 000 ₽, Удалёнка.

Бустер — Удалённо (в любом городе мира).

➡️ Еще больше топовых вакансий — в нашем канале С# Jobs
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔4🔥3
💻 Компактный гид по основам языка

Нашли для вас шпаргалку, которая охватывает все основные темы языка. Код можно скопировать и поиграться в своей среде разработки.

➡️ Поделитесь с младшими коллегами

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8😁5🥱1
Грин-флаги в вакансиях: 10 признаков хорошего работодателя

Пока одни сосредоточены на том, как произвести впечатление на работодателя, опытные соискатели внимательно читают вакансии и ищут признаки того, что перед ними достойная компания.

В статье подробно о том, как распознать хорошего работодателя ещё до собеседования, просто внимательно вчитавшись в текст вакансии.

📎 Читать статью

🐸Библиотека шарписта
Please open Telegram to view this post
VIEW IN TELEGRAM
⚙️ Как проверить, что WeakReference «отпустила» объект

В .NET слабые ссылки позволяют ссылаться на объект, не препятствуя сборщику мусора его удалить. Это полезно в кэшах, пулах объектов и других случаях, где важно избегать утечек памяти.

Но как проверить, что объект удаляется?

Можно использовать пример:
class MyObject
{
~MyObject()
{
Console.WriteLine("MyObject был удалён сборщиком мусора");
}
}

class Program
{
static void Main()
{
WeakReference weakRef = test();

GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();

Console.WriteLine("После сборки мусора: " + (weakRef.IsAlive ? "Жив" : "Удалён"));
}

static WeakReference test() {
var obj = new MyObject();
WeakReference weakRef = new WeakReference(obj);
Console.WriteLine("До удаления ссылки: " + (weakRef.IsAlive ? "Жив" : "Удалён"));
return weakRef;
}
}


IsAlive показывает, жив ли объект.

GC.Collect() + GC.WaitForPendingFinalizers() заставляют сборщик мусора немедленно освободить неиспользуемые объекты.

• Деструктор ~MyObject() позволяет наглядно убедиться, что объект удалён.

Метод IsAlive может показывать, что объект жив даже после GC.Collect(), если объект ещё не финализирован или находится в очереди на финализацию.

Для надёжности можно использовать TryGetTarget вместо IsAlive.

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍223🔥1😁1
📋 Чек-лист по написанию LINQ запросов

Независимо от того, работаете ли вы с коллекциями, базами данных или XML, LINQ запросы требуют правильной структуры и оптимизации для достижения наилучших результатов.

В этом чек-листе собраны основные моменты, которые помогут вам писать чистые, читаемые и эффективные LINQ запросы.

Понимание источника данных

Убедитесь, что данные поддерживают LINQ, например, IEnumerable<T> или IQueryable<T>.

Определение цели запроса

Чётко определите входные данные, что с ними будет в процессе и какие ожидаются данные на выходе.

Синтаксис запроса

Перед написанием запросов стоит определить какой синтаксис будет использоваться.

• Синтаксис как метод:
var result = collection.Where(x => x.Age > 30).OrderBy(x => x.Name).ToList();


• Запрос в синтаксисе:
var result = from x in collection
where x.Age > 30
orderby x.Name
select x;


Оптимизация производительности

Используйте IQueryable<T> для внешних источников данных (например, базы данных), чтобы запрос выполнялся на сервере.

Отложенная и немедленная загрузка

Отложенная загрузка полезна, когда вам нужно выполнить запрос, но выполнение следует отложить до тех пор, пока это не потребуется.

Немедленная загрузка используется, когда вы хотите сразу получить результат выполнения запроса или когда данные нужно обработать немедленно.

Агрегация и группировка

Используйте функции агрегации, такие как Sum(), Average(), Max(), и группировку через GroupBy().

Сложные запросы

Работайте с несколькими коллекциями через операторы join, union, intersect и except.
var combined = collection1.Join(collection2, 
c1 => c1.Id,
c2 => c2.Id,
(c1, c2) => new { c1.Name, c2.Price });


Использование let для промежуточных вычислений

Упрощайте запросы с помощью промежуточных переменных:
var result = from x in collection
let temp = x.Age * 2
where temp > 40
select new { x.Name, temp };


Обработка пустых коллекций

Используйте DefaultIfEmpty() для предотвращения ошибок при работе с пустыми коллекциями.

Производительность и асинхронность

Используйте асинхронные методы, такие как ToListAsync(), для работы с асинхронными источниками данных.

🐸Библиотека шарписта #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍133👾1
🚨 Смешные новости про IT теперь в одном канале

Мы запустили @hahacker_news — наш новый юмористический IT-канал.

Туда будем постить лучшие шутки до 19го мая, которые вы присылали на конкурс.

👉 @hahacker_news — голосование уже идёт, переходите, читайте, угарайте и оставляйте реакции
😁3
📦 Истории подписчиков: расскажите про свои первые пул реквесты

Первый pull request — это как первая любовь: кажется, что всё идеально… пока тебе не скажут, что ты написал монстра на 240 строк в контроллере.

Монстром в контроллере поделился наш подписчик:
Мой первый pull request. Первый проект. Я хотел показать, как умею быстро писать код. Ну и засунул абсолютно всё в контроллер: валидацию, обращение к БД, бизнес-логику, обработку ошибок. Зато как быстро я всё это наклепал! Жаль, потом по рукам надавали и сказали переделать..


💬 А у вас были такие первые PR'ы, после которых стало стыдно, но полезно? Расскажите в комментах — пусть новички учатся не только на своих ошибках 👇

P.S. Если хотите задать вопрос сообществу, заполните нашу гугл-форму.

🐸Библиотека шарписта #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
😁10👍3