C# | Вопросы собесов
Открыть в Telegram
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+nebTPWgpeGs1OWFi Задачи t.me/+Xy-0H7xKlgo0NDVi Вакансии t.me/+BQFHXZQ0zrViNGIy
Больше5 048
Подписчики
-124 часа
-177 дней
-2630 день
Архив постов
5 048
📌 Что такое DI(инъекция зависимости)?
💬 Спрашивают в 22% собеседований
Dependency Injection (DI), или инъекция зависимости, — это шаблон проектирования, который позволяет объектам получить свои зависимости от внешних источников, а не создавать их самостоятельно. Этот подход улучшает тестируемость, расширяемость и поддерживаемость кода, делая его более гибким и модульным.
🤔 Основные концепции
1️⃣ Зависимость: Любой объект или класс, от которого зависит другой объект или класс. Например, если класс
A использует класс B для выполнения своих задач, то B является зависимостью для A.
2️⃣ Инъекция зависимости: Процесс предоставления зависимости объекту извне, обычно через конструктор, метод или свойство.
🤔 Преимущества DI
➕ Улучшенная тестируемость: Легко заменять реальные зависимости на моки или заглушки, что упрощает модульное тестирование.
➕ Ослабленная связность: Классы не жестко связаны с конкретными реализациями своих зависимостей, что упрощает их замену и изменение.
➕ Расширяемость и поддерживаемость: Позволяет легко добавлять новые функциональные возможности и изменять существующие зависимости.
🤔 Виды инъекций зависимости
1️⃣ Конструкторная инъекция: Зависимости передаются через параметры конструктора. public class Service
{
private readonly IRepository _repository;
public Service(IRepository repository)
{
_repository = repository;
}
public void DoWork()
{
_repository.Save();
}
}
2️⃣ Инъекция через свойства: Зависимости устанавливаются через свойства класса. public class Service
{
public IRepository Repository { get; set; }
public void DoWork()
{
Repository.Save();
}
}
3️⃣ Инъекция через методы: Зависимости передаются через параметры метода. public class Service
{
private IRepository _repository;
public void SetRepository(IRepository repository)
{
_repository = repository;
}
public void DoWork()
{
_repository.Save();
}
}
🤔 Использование DI с IoC-контейнерами
IoC-контейнеры (контейнеры инверсии управления) управляют созданием и жизненным циклом зависимостей, а также автоматизируют процесс их инъекции. Пример использования популярного IoC-контейнера Autofac:
1️⃣ Установка Autofac: Добавляем пакет Autofac через NuGet Package Manager.
2️⃣ Настройка контейнера и регистрация зависимостей: using Autofac;
var builder = new ContainerBuilder();
builder.RegisterType<Repository>().As<IRepository>();
builder.RegisterType<Service>().As<IService>();
var container = builder.Build();
3️⃣ Разрешение зависимостей и использование сервиса: using (var scope = container.BeginLifetimeScope())
{
var service = scope.Resolve<IService>();
service.DoWork();
}
🤔 Краткий ответ
Dependency Injection (DI) — это метод предоставления зависимостей объекту извне, что делает код более гибким, тестируемым и поддерживаемым. DI может осуществляться через конструкторы, свойства или методы, а IoC-контейнеры автоматизируют процесс управления зависимостями.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых5 048
Новый AI, который составляет протокол вместо человека
Таймлист за считанные минуты предоставляет готовый протокол и конспект совещания.
1. Расшифрует речь
2. Определит спикеров
3. Составит полную стенограмму
4. Напишет краткий конспект
5. Распределит задачи
Не выходя из сервиса, вы получаете полностью готовую расшифровку и протокол обсуждения, который готов к скачиванию или копированию в удобном для Вас формате в один клик.
Попробуйте бесплатно и запишитесь на демо-встречу.
Опробовав Таймлист вы удивитесь, как раньше обходились без него!
Попробовать
#реклама
timelist.ru
О рекламодателе
5 048
📌 Какие колекции знаешь?
💬 Спрашивают в 22% собеседований
В C# существует множество коллекций, которые предоставляются в стандартной библиотеке .NET. Они делятся на несколько категорий, каждая из которых предназначена для различных сценариев использования. Вот основные типы коллекций:
1️⃣ Коллекции общего назначения
➕ List<T>: Динамический массив, который автоматически изменяет свой размер по мере добавления элементов.
List<int> numbers = new List<int> { 1, 2, 3, 4 };
numbers.Add(5);
➕ Dictionary<TKey, TValue>: Коллекция пар ключ-значение. Обеспечивает быстрый доступ к значению по ключу. Dictionary<string, int> ages = new Dictionary<string, int>
{
{ "Alice", 30 },
{ "Bob", 25 }
};
int aliceAge = ages["Alice"];
➕ HashSet<T>: Коллекция уникальных элементов. Используется для проверки наличия элемента и предотвращения дублирования. HashSet<string> fruits = new HashSet<string> { "Apple", "Banana" };
fruits.Add("Apple"); // Не добавит дубликат
➕ Queue<T>: Очередь, работающая по принципу FIFO (First In, First Out). Queue<string> queue = new Queue<string>();
queue.Enqueue("first");
queue.Enqueue("second");
string item = queue.Dequeue(); // "first"
➕ Stack<T>: Стек, работающий по принципу LIFO (Last In, First Out). Stack<string> stack = new Stack<string>();
stack.Push("first");
stack.Push("second");
string item = stack.Pop(); // "second"
2️⃣ Специализированные коллекции
➕ LinkedList<T>: Двусвязный список, позволяющий быстро вставлять и удалять элементы. LinkedList<int> linkedList = new LinkedList<int>();
linkedList.AddLast(1);
linkedList.AddLast(2);
➕ SortedList<TKey, TValue>: Коллекция пар ключ-значение, отсортированная по ключам. SortedList<string, int> sortedList = new SortedList<string, int>
{
{ "Alice", 30 },
{ "Bob", 25 }
};
➕ SortedDictionary<TKey, TValue>: Похож на SortedList, но использует бинарное дерево для хранения элементов. SortedDictionary<string, int> sortedDict = new SortedDictionary<string, int>
{
{ "Alice", 30 },
{ "Bob", 25 }
};
➕ SortedSet<T>: Отсортированное множество уникальных элементов. SortedSet<int> sortedSet = new SortedSet<int> { 3, 1, 2 };
3️⃣ Коллекции для параллельного программирования
➕ ConcurrentDictionary<TKey, TValue>: Параллельная версия Dictionary, предназначенная для безопасного использования в многопоточных приложениях. ConcurrentDictionary<string, int> concurrentDict = new ConcurrentDictionary<string, int>();
concurrentDict.TryAdd("Alice", 30);
➕ ConcurrentQueue<T>: Параллельная версия Queue. ConcurrentQueue<string> concurrentQueue = new ConcurrentQueue<string>();
concurrentQueue.Enqueue("first");
➕ ConcurrentStack<T>: Параллельная версия Stack. ConcurrentStack<string> concurrentStack = new ConcurrentStack<string>();
concurrentStack.Push("first");
➕ BlockingCollection<T>: Коллекция, поддерживающая операции добавления и извлечения с блокировкой и ограничением по емкости. BlockingCollection<int> blockingCollection = new BlockingCollection<int>(5);
blockingCollection.Add(1);
🤔 Краткий ответ
В C# есть множество коллекций для различных целей, включая List, Dictionary, HashSet, Queue, Stack, специализированные коллекции, такие как LinkedList, SortedList, а также коллекции для параллельного программирования, такие как ConcurrentDictionary и BlockingCollection.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых5 048
На эти IT-стажировки берут без опыта
В канале собраны самые свежие предложения от крупнейших российских компаний: VK, Сбера, Яндекса и многих других.
Теперь можно не откладывать начало карьеры в IT, ведь здесь вы найдете:
— стажировки для молодых специалистов;
— анонсы хакатонов, которые будут выгодно смотреться в резюме;
— карьерные и образовательные ивенты для прокачки hard и soft skills.
Подписаться
#реклама
О рекламодателе
5 048
🤔 Какое ключевое слово в C# используется для создания метода, который может быть переопределён в производном классе?
5 048
👨💻 Джун: Слушай, вот стажировку я прошел, где теперь можно чекнуть вакансии на работу?
🍷 Мидл: Ооо, тебе помогут ребята с канала Джун работает
💯 Карьеру нужно начинать с хорошими работодателями. Твое резюме будет ликовать, ведь контент выходит каждый день, работа ждет тебя, мой друг!
😏 Не упускай возможность и подписывайся, чтобы не потерять
5 048
📌 Что такое принцип подстановки Барбары Лисков?
💬 Спрашивают в 22% собеседований
Принцип подстановки Барбары Лисков (Liskov Substitution Principle, LSP) - это один из пяти принципов SOLID, который гласит, что объекты подтипов должны быть заменяемы объектами базового типа без нарушения правильности работы программы. Это означает, что если класс
B является подтипом класса A, то объекты класса A могут быть заменены объектами класса B без изменения желаемого поведения программы.
🤔 Основные понятия
1️⃣ Наследование: Подтипы должны наследовать не только интерфейс, но и поведение базовых типов.
2️⃣ Замена: Класс-наследник должен корректно работать в любом контексте, где ожидается объект базового класса.
3️⃣ Контракт: Подтип должен соблюдать контракт базового типа, что включает предусловия, постусловия и инварианты.
🤔 Почему это нужно
➕ Упрощение понимания и поддержки кода: Код, который следует LSP, более предсказуем и понятен, что облегчает его поддержку.
➕ Повышение надежности: Соблюдение принципа помогает избежать неожиданных ошибок при замене объектов базового класса на объекты подклассов.
➕ Расширяемость: Принцип способствует созданию гибкой и расширяемой архитектуры, в которой новые подтипы можно добавлять без риска нарушения существующего кода.
🤔 Пример нарушения LSP
Рассмотрим пример, где нарушение LSP приводит к некорректному поведению программы: public class Rectangle
{
public virtual int Width { get; set; }
public virtual int Height { get; set; }
public int GetArea()
{
return Width * Height;
}
}
public class Square : Rectangle
{
public override int Width
{
set { base.Width = base.Height = value; }
}
public override int Height
{
set { base.Width = base.Height = value; }
}
}
🤔 Проблема
В этом примере Square (квадрат) наследует от Rectangle (прямоугольник). Однако, квадрат имеет особое свойство: его ширина и высота всегда равны. При попытке установить ширину или высоту квадрата, изменяется и другое значение, что нарушает поведение прямоугольника.
🤔 Исправление
Лучше использовать композицию вместо наследования для избежания такой проблемы: public interface IShape
{
int GetArea();
}
public class Rectangle : IShape
{
public int Width { get; set; }
public int Height { get; set; }
public int GetArea()
{
return Width * Height;
}
}
public class Square : IShape
{
public int SideLength { get; set; }
public int GetArea()
{
return SideLength * SideLength;
}
}
🤔 Объяснение
1️⃣ Интерфейс IShape: Определяем общий интерфейс для всех форм.
2️⃣ Реализация прямоугольника и квадрата: Классы Rectangle и Square реализуют интерфейс IShape, но теперь они не наследуются друг от друга и имеют свои собственные свойства и методы.
🤔 Краткий ответ
Принцип подстановки Лисков гласит, что объекты подтипов должны быть заменяемы объектами базового типа без нарушения работы программы. Это необходимо для повышения предсказуемости, надежности и расширяемости кода.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых5 048
📕 Прогер, как ты расширяешь свой кругозор в сфере IT?
Не достаточно знать что-то одно, мысля глобально и изучая смежные отрасли, ты не только становишься умнее, но и увеличиваешь свою востребованность и свой заработок.
🗿 Не обязательно читать заумные книги и смотреть подкасты - это долго.
У нас есть решение:
🔥 Полезные статьи - концентрат знаний.
🔥 Советы - короткие сообщения, которые будут увеличивать твою эффективность.
🔥 Инструменты - tool-сайты в разы упростят и ускорят твою работу.
🧑💻 Время, силы, желание - ресурсы, которые нужно использовать с умом. Подпишись на канал Заметки прогера, IT ниша скажет "спасибо" за такого специалиста.
5 048
Начните карьеру в IT в Яндексе, VK, Сбере или МТС
В канале собраны самые актуальные стажировки в крупнейших компаниях.
Не упустите возможность найти:
— вакансии для джунов и кандидатов без опыта у лучших работодателей;
— хакатоны, на которых можно получить сертификаты и кейсы для резюме;
— карьерные ивенты, где можно прокачать свои скиллы и заработать денег
Подписаться
#реклама
О рекламодателе
5 048
🤔 Какой из следующих методов C# используется для явного указания, что объект должен быть собран сборщиком мусора?
5 048
😭 Джун: Как мне найти работу в IT, если опыта нет?
🧑💻 Мидл: Просто зайди на канал Джун стажер и подбери стажировку по душе.
📕 Админы отбирают самые сочные вакансии от ведущих компаний, к тому же контент выходит каждый день.
🔥 Не упускай возможность и подписывайся, чтобы не потерять
5 048
ТОП-4 Курса по Программированию
⚡Tutortop — маркетплейс курсов №1 по количеству школ-партнеров, курсов и реальных отзывов студентов.
✅Хотите стать программистом, но не знаете с какого языка начать?
Помогаем разобраться в самых популярных и востребованных языках программирования.
Подарок в конце подборки!
Выбрать
#реклама 16+
tutortop.ru
О рекламодателе
5 048
📌 Что такое IoC-контейнеры?
💬 Спрашивают в 22% собеседований
IoC (Inversion of Control) контейнеры – это фреймворки или библиотеки, которые управляют созданием и внедрением зависимостей в приложении. Они помогают реализовать принцип внедрения зависимостей (Dependency Injection), что делает код более гибким, тестируемым и легко расширяемым.
🤔 Основные понятия
1️⃣ Inversion of Control (IoC): IoC – это принцип, при котором управление объектами и их зависимостями передается внешней системе или фреймворку, вместо того чтобы объекты самостоятельно управляли своими зависимостями.
2️⃣ Dependency Injection (DI): DI – это метод внедрения зависимостей, при котором зависимости (объекты, от которых зависит другой объект) предоставляются внешним источником (например, IoC-контейнером) вместо того, чтобы объект создавал их самостоятельно.
🤔 Почему это нужно
➕ Упрощение тестирования: Легко заменять зависимости на заглушки или моки, что облегчает тестирование.
➕ Снижение связности кода: Объекты не зависят от конкретных реализаций своих зависимостей, а зависят от абстракций (интерфейсов), что упрощает изменение и расширение кода.
➕ Централизованное управление зависимостями: IoC-контейнеры управляют жизненным циклом объектов и их зависимостей, что делает код более организованным и понятным.
🤔 Пример использования IoC-контейнера
Рассмотрим простой пример использования популярного IoC-контейнера Autofac в C#:
1️⃣ Установка Autofac: Добавляем пакет Autofac через NuGet Package Manager.
2️⃣ Создание интерфейсов и классов:
public interface ILogger
{
void Log(string message);
}
public class ConsoleLogger : ILogger
{
public void Log(string message)
{
Console.WriteLine(message);
}
}
public interface IService
{
void Serve();
}
public class Service : IService
{
private readonly ILogger _logger;
public Service(ILogger logger)
{
_logger = logger;
}
public void Serve()
{
_logger.Log("Service Called");
}
}
3️⃣ Настройка и использование IoC-контейнера: using Autofac;
class Program
{
static void Main(string[] args)
{
var builder = new ContainerBuilder();
// Регистрируем зависимости
builder.RegisterType<ConsoleLogger>().As<ILogger>();
builder.RegisterType<Service>().As<IService>();
// Строим контейнер
var container = builder.Build();
// Разрешаем зависимости
var service = container.Resolve<IService>();
service.Serve();
}
}
🤔 Объяснение кода
1️⃣ Интерфейсы и реализации: Мы создаем интерфейсы ILogger и IService, а также их реализации ConsoleLogger и Service.
2️⃣ Регистрация зависимостей: С помощью ContainerBuilder регистрируем классы ConsoleLogger и Service как реализации соответствующих интерфейсов.
3️⃣ Разрешение зависимостей: С помощью контейнера разрешаем зависимости и вызываем метод Serve у объекта Service, который использует ConsoleLogger для логирования.
🤔 Краткий ответ
IoC-контейнеры управляют созданием и внедрением зависимостей в приложении, упрощая тестирование и организацию кода. Они позволяют регистрировать и разрешать зависимости, делая код более гибким и легко расширяемым.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых5 048
👨💻 Будущий специалист, ты знаешь, какая самая частая ошибка новичка в сфере IT?
Отсутствие практики убивает в тебе потенциал
✈️ Как с этим бороться, мой друг?
Найди работу и прокачивай свои скилы на конкретных задачах
🔥 У нас ты будешь находить большое количество вакансий каждый день. Понятие работы перестанет быть для тебя размытым.
Подпишись на канал и не откладывай свой прогресс в долгий ящик.
5 048
Jobski - твой помощник при поиске работы в IT
Сервис индивидуально подбирает вакансии, учитывая ваш опыт, навыки и стек технологий.
Узнать больше
#реклама
jobski.ru
О рекламодателе
5 048
🤔 Какое ключевое слово в C# используется для объявления блока кода, который гарантированно выполнится после завершения блока try?
5 048
🧑💻 Если твой английский позволяет ответить только на вопрос "Do you speak English", то с этим нужно что-то делать, будучи программистом.
🫤 Ты в курсе, что ...
- говорят по-английски — 20% из всех людей.
- Большое кол-во IT документации написано на английском.
Хочешь понимать код лучше? Изучи язык, который используется в его основе.
📕 На нашем канале ты постепенно будешь набираться опыта, в этом тебе помогут:
- Тесты для изучения английского: проверьте свои знания на практике.
- Английский через мемы: учите язык весело и с интересом.
- Шпаргалки для повторения: закрепите знания быстро и эффективно.
- Английский сленг программиста: станьте настоящим профи в коммуникации.
🔥 Маленький шаг в изучении иностранного откроет перед тобой большие возможности будущего специалиста и значительно повысит твое зп.
🌸 Подпишись, do it!
5 048
📌 Что такое мультикаст-делегат?
💬 Спрашивают в 22% собеседований
Мультикаст-делегат в C# - это тип делегата, который может ссылаться на несколько методов. Это позволяет вызывать несколько методов в одном вызове делегата. Такая возможность полезна для выполнения последовательности действий, таких как уведомление нескольких подписчиков о событии.
🤔 Основные понятия
1️⃣ Делегат: Делегат - это тип, который определяет сигнатуру метода и может ссылаться на любой метод с совместимой сигнатурой. Делегаты похожи на указатели на функции в C++, но являются типобезопасными и встроены в систему типов C#.
2️⃣ Мультикаст-делегат: Это делегат, который может содержать список методов. Когда вызывается мультикаст-делегат, все методы в его списке вызываются в порядке их добавления.
🤔 Почему это нужно
➕ Уведомление нескольких объектов: Мультикаст-делегаты широко используются в системе событий .NET. Например, когда происходит какое-то событие (например, изменение состояния объекта), все подписчики на это событие могут быть уведомлены через мультикаст-делегат.
➕ Легкость добавления и удаления методов: Методы могут быть легко добавлены или удалены из списка вызовов делегата, что делает их гибким инструментом для динамического управления логикой программы.
🤔 Использование мультикаст-делегатов
Создадим простой пример, где мультикаст-делегат используется для уведомления нескольких методов:
using System;
public class Program
{
// Определяем делегат, который принимает строку и ничего не возвращает
public delegate void Notify(string message);
// Метод, который соответствует сигнатуре делегата
public static void SendEmail(string message)
{
Console.WriteLine($"Email sent: {message}");
}
// Другой метод, который соответствует сигнатуре делегата
public static void LogMessage(string message)
{
Console.WriteLine($"Log entry: {message}");
}
public static void Main()
{
// Создаем экземпляр делегата и добавляем методы
Notify notifyDel = SendEmail;
notifyDel += LogMessage;
// Вызываем делегат
notifyDel("System update available.");
// Удаляем метод из делегата
notifyDel -= LogMessage;
// Вызываем делегат снова
notifyDel("Security patch applied.");
}
}
🤔 Объяснение кода
1️⃣ Определение делегата: Мы объявляем делегат Notify, который принимает строку в качестве параметра и не возвращает значение.
2️⃣ Создание методов: Два метода SendEmail и LogMessage, которые соответствуют сигнатуре делегата Notify.
3️⃣ Создание экземпляра делегата: Мы создаем экземпляр делегата и добавляем методы в список вызовов.
4️⃣ Вызов делегата: Когда мы вызываем делегат, он вызывает все методы в своем списке.
5️⃣ Удаление метода из делегата: Мы удаляем метод LogMessage из списка вызовов делегата.
🤔 Краткий ответ
Мультикаст-делегат - это делегат, который может ссылаться на несколько методов и вызывать их последовательно. Это полезно для выполнения нескольких действий в одном вызове, таких как уведомление нескольких подписчиков о событии.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых5 048
Запустите рекламу в телеграм-каналах с Яндекс Директом
Перфоманс-реклама теперь в телеграм-каналах ⚡
Яндекс Директ знает, как привлечь целевую аудиторию 💰👌
Попробовать
#реклама
yandex.ru
О рекламодателе
Уже доступно! Исследование Telegram 2025 — ключевые инсайты года 
