Computer Science
رفتن به کانال در Telegram
По всем вопросам: @altmainf Уважаемый менеджер: @altaiface
نمایش بیشتر7 924
مشترکین
-124 ساعت
-87 روز
-2530 روز
آرشیو پست ها
7 924
Суть кэширования процессора
Так как скорость работы процессора отличается от скорости работы оперативной памяти, то возникают простои и страдает производительность, чтобы этого избежать, появляется маленькая, но быстрая память под названием кэш.
Суть кэширования заключается в сокращении задержек доступа, касающиеся взаимодействия с оперативной памятью.
Кэш память, которая меньше по объему оперативы примерно в 1000 раз, но по скорости работы сопоставима со скоростью работы процессора отлично вписалась в общую модель работы компьютера, ничего при этом не сломав. Вообще кэш по прежнему можно рассматривать, как обычную ОП, только в уменьшенном размере.
И там, и там используется двоичная адресация, хранятся те же самые данные. И к той, и той памяти идет обращение, как на получение данных, так и на их запись.
Логика в том, что если данные будут находится в кэше, а не в оперативе, то это и избавит нас от задержек.
7 924
Дизайн в FIGMA с нуля. Бесплатный курс + портфолио
Онлайн-программа с наставником и чатом. Дизайн от профессионалов. Доступ 0 руб.
Узнать больше
#реклама
yudaevschool.online
О рекламодателе
7 924
О-большое (Big O)
Нотация О-большое описывает скорость работы алгоритма в худшем случае.
Предположим вы используете простой поиск для поиска фамилии телефоном справочнике. Вы знаете, что простой поиск выполняется за время O(n) - то есть в худшем случае вам придется пересмотреть все фамилии в справочнике, но представим, что наша искомая фамилия начинается с «А» и находится в самом начале справочника. Следовательно, мы нашли нужную фамилию с первой попытки. Отработал ли алгоритм за время O(n)? А может, он занял время O(1)?
Простой поиск все равно выполняется за время O(n). Просто в данном случае вы нашли нужное значение моментально — это лучший возможный случай.
7 924
Получи грант на обучение в Центральном университете
Центральный университет выдает гранты на 4 года обучения в бакалавриате. Гранты покрывают 100%, 75%, 50% и 25% стоимости обучения.
Участвуй в отборе, чтобы получить грант. Подай заявку, пройди онлайн-тест на математическое и логическое мышление, а затем прими участие в бизнес-игре. Попытки не ограничены.
Для выпускников 11-х классов и колледжей.
Подать заявку
#реклама
apply.centraluniversity.ru
О рекламодателе
7 924
«Битый сектор» или «бэд сектор»
Сталкиваясь с понятиями «битый сектор» или начинающие пользователи обычно понимают, что речь идет о какой-то серьезной проблеме, но не понимают как эту проблему решать.
Допустим, что жесткий диск вашего компьютера подвергся низкоуровневому форматированию на заводе-изготовителе. В результате этого процесса на магнитном носителе были созданы дорожки и сектора, которые в процессе работы компьютера используются для хранения данных. Сектора – это физически размеченные области на поверхности магнитного носителя, предназначенные для хранения данных.
Если такой сектор будет поврежден механически, то вся информация, которая в нем хранилась, будет безвозвратно утеряна.
Такие поврежденные механически сектора и называются битыми секторами. В них уже невозможно хранить данные и те данные, которые были в них записаны ранее, с большей долей вероятности восстановить не получится.
7 924
Иногда главное — не только внимание.
Превосходные подарки для самых искушенных ценителей прекрасного.
BORK. Фабрика ваших желаний.
Детали и стоимость на сайте и в мобильном приложении.
Перейти на сайт
#реклама 0+
bork.ru
О рекламодателе
7 924
Что такое хеш-таблицы?
Хеш-таблица — это контейнер для хранения пар ключей и их значений. По сути это ассоциативный массив, в котором ключ представлен в виде хеш-функции. Главное свойство hash-таблиц — три операции: вставка, поиск и удаление — в среднем выполняются за время O(1),
Принято считать, что хорошей, с точки зрения практического применения, является такая хеш-функция, которая удовлетворяет следующим условиям:
⁃ функция должна быть простой с вычислительной точки зрения;
⁃ функция должна распределять ключи в хеш-таблице наиболее равномерно;
⁃ функция не должна отображать какую-либо связь между значениями ключей в связь между значениями адресов;
⁃ функция должна минимизировать число коллизий – то есть ситуаций, когда разным ключам соответствует одно значение хеш- функции(ключи в этом случае называются синонимами ).
Выполнение операции в хеш-таблице начинается с вычисления хеш-функции от ключа.
Именно с ее помощью мы находим индекс, зная который, можно выполнить требующую операцию.
7 924
Плюсы и минусы рекурсивных функций
Плюсы:
1. Снижают время выполнения функции
Рекурсия, в сравнении с циклами, тратят меньше времени до завершении функции. Чем меньше строк кода у нас будет, тем быстрее функция будет обрабатывать вызовы внутри себя.
НО
Если функция плохо написана, то мы рискуем переполнить стек, что в конечном счете приведет к снижению скорости и программным ошибкам.
2. Легче отлаживать
Многие согласятся, что эта причина очень важна. Рекурсия проста в отладке из-за того, что она не содержит сложных и длинных конструкций.
Минусы:
3. Занимают много места
Занимают значительный объем памяти во время своего выполнения. При каждом вызове функции в стек будет добавляться новый элемент, который будет занимать место до тех пор, пока функция не завершит работу.
7 924
Рекурсия
В программирование рекурсия — вызов функции самой себя. Это используется для реализации большого спектра самых разнообразных задач связанных с перебором (перебор чисел, букв, объектов, файлов и тд).
Чтобы понять как работает рекурсия, желательно понимать как работает стек, так как реализация рекурсивных вызовов функций опирается на механизм стека вызовов — адрес возврата и локальные переменные функции записываются в стек, благодаря чему каждый следующий рекурсивный вызов этой функции пользуется своим набором локальных переменных и за счёт этого работает корректно.
Оборотной стороной этого довольно простого по структуре механизма является то, что на каждый рекурсивный вызов требуется некоторое количество оперативной памяти компьютера, и при чрезмерно большой глубине рекурсии может наступить переполнения стека вызовов.
7 924
Домены
Имена в DNS (Domain Name System) называются доменными именами или доменами. Они состоят из текстовых меток, разделенных точками. Метки могут использовать 26 букв от а до z, цифры от 0 до 9, а также дефис (-).
Например:
home-3.coding.exemple — это домен с тремя метками.
Точки обозначают иерархические поддомены. Это домены, контролируемые более коротким родительским доменом: home-3.coding.exemple является поддоменом coding.exemple. Кроме того, coding.exemple является поддоменом однокомпонентного домена exemple. Домены нечувствительны к регистру: coding.exemple и CoDing.eXamplE идентичны.
Домены из одной метки, такие как com, net, а также exemple, называются доменами высшего уровня (Top Level Domains, TLDs). Благодаря своему устройству DNS наиболее эффективен при ограниченном количестве TLD. По этой причине создание новых TLD представляет сложность.7 924
Когда следует использовать язык ассемблера
Программисты, которые пишут код на языке ассемблера, говорят, что у такого подхода есть три преимущества. Первые два очевидны: код занимает меньше места и работает быстрее. Третье не столь очевидно: если в коде есть ошибка, то она, как правило, приводит к катастрофическому сбою. На первый взгляд это не кажется преимуществом, однако сразу дает понять, что вы сделали что-то не так.
В подавляющем большинстве случаев проще работать на высокоуровневом языке. Язык ассемблера стоит использовать при работе со встроенными системами с ограниченной вычислительной мощностью, особенно когда экономия места позволяет задействовать более дешевые процессоры.
В случае создания крупномасштабных приложений экономия на процессорах может более чем компенсировать дополнительное время разработчика. Например, программы DSP (цифровой обработки сигналов) часто пишутся на языке ассемблера.
7 924
Кредит для бизнеса в Альфа-Банке
Скидка на ставку до 3,5% за подключение полезных услуг и сервисов.
Скидка до 8% при оформлении подписки на кредитные линии.
Сумма за 5 минут. Узнайте размер доступного кредита без открытия расчетного счета
Деньги сразу на счет ИП или юрлица.
Подать заявку
Финансовые услуги оказывает: АО "АЛЬФА-БАНК", АО "АльфаСтрахование"
#реклама
alfabank.ru
О рекламодателе
7 924
Принципы построения современных ОС
1. Принцип модульности
Мы говорим о системных программных модулях, которые являются программными ресурсами и могут быть распределены между выполняющимися процессами. Этот принцип отражает технологические и эксплуатационные свойства системы.
2. Принцип параметрической настраиваемости
Возможность учета ОС параметров конфигурации ВС называется параметрической настраиваемостью. ОС должна быть способна распознавать как старые, так новые устройства и обеспечивать их работу.
3. Принцип функциональной избыточности
Принцип функциональной избыточности состоит во включении в состав ОС различных программных средств, выполняющих одну и ту же функцию, но которые в различных ситуациях работают с различной эффективностью.
4. Принцип функциональной избирательности
Принцип функциональной избирательности состоит в возможности учета целей, для которых используется система. Воплощение этого принципа позволяет в зависимости от области применения сгенерировать такой вариант системы, который был бы эффективен в данном конкретном применении.
5. Принцип абстракции и виртуализации
Использование интерфейсов, отделяющие друг от друга уровни абстракции, облегчает независимую разработку аппаратных и программных подсистем силами разных групп специалистов.
7 924
Основные аспекты человеко-машинного взаимодействия:
Интерфейсы пользователя: Разработка графических интерфейсов, виртуальных клавиатур, жестов и других элементов, которые позволяют людям взаимодействовать с компьютером.
Эргономика: Изучение того, как дизайн интерфейсов может быть адаптирован к физиологии и психологии человека для обеспечения максимального комфорта и эффективности в использовании.
Ввод и вывод данных: Разработка средств ввода и вывода, таких как сенсорные экраны, голосовые команды, трекпады и т.д.
Доступность: Создание технологий, которые делают компьютерные системы доступными для людей с ограниченными возможностями.
Визуализация данных: Представление информации в удобной форме для восприятия и понимания.
Интерактивный дизайн: Разработка интерфейсов, которые стимулируют взаимодействие и обеспечивают позитивный опыт пользователей.
7 924
Хеширование
Hashing – это преобразование входного массива данных определенного типа и произвольной длины в выходную битовую строку фиксированной длины. Такие преобразования также называются хеш-функциями или функциями свертки, а их результаты называют хешем, хеш-кодом, хеш-таблицей или дайджестом сообщения
Хеширование является распространенным методом обеспечения быстрого доступа к информации, хранящейся во внешней памяти. Оно полезно, когда широкий диапазон возможных значений должен быть сохранен в малом объеме памяти, и нужен способ быстрого, практически произвольного доступа.
Хэш-таблицы часто применяются в базах данных, и, особенно, в языковых процессорах типа компиляторов и ассемблеров, где они повышают скорость обработки таблицы идентификаторов. В качестве использования хеширования в повседневной жизни можно привести примеры распределение книг в библиотеке по тематическим каталогам, упорядочивание в словарях по первым буквам слов, шифрование специальностей в вузах и т.д.
7 924
Требуется разработчик С++ Backend / Платформа обработки данных
ООО «Лаборатория Современных Цифровых Технологий» – Разработчик программного обеспечения
Обязанности:
• Разработка микросервисов и алгоритмов для поиска и обработки данных
• Разработка высоконагруженных сервисов для обслуживания запросов пользователей
• Разработка документации и описание используемых алгоритмов
• Разработка unit/malfunction/regression/performance тестов.
• Оптимизация кода и разработка надежного кода;
Требования:
• Имеет опыт коммерческой разработки ПО на С++ от 3 лет
• Имеет опыт работы с библиотеками Boost/STL
• Понимает принципы ООП С++ и знает базовые идиомы С++
• Владеет основами отладки кода Linux GDB
• Имеет опыт разработки TCP/IP приложений в Linux
• Умеет работать с механизмами IPC в Linux
• Имеет навыки работы с реляционными / не реляционными БД (Будет большим плюсом)
• Опыт работы в команде
• Знание SQL, умение писать и оптимизировать SQL запросы
Плюсами будут:
• Быстрая обучаемость
• Английский язык на уровне чтения документации
Условия работы:
• Оклад от 300 000 ₽;
• Уютный офис в г.Москва
• Молодой дружный коллектив профессионалов
• ДМС, официальное трудоустройство по ТК РФ
• Дистанционный или гибридный формат работы после успешного прохождения испытательного срока
• Повышение зарплаты при переходе по грейдам
• Самое важное для нас — мотивация сотрудника, желание расти, эффективное решение задач
Откликнуться на почту: hr@digtechlab.ru
7 924
Особенности удаления файлов на SSD-носителях
В SSD-накопителе, как и в HDD, данные не удаляются сразу после того, как файл был стёрт из ОС. Даже если затереть файл нулями, физически данные ещё остаются, и если чипы флэш-памяти достать и считать на программаторе – можно найти 4 КБ фрагменты файлов. Полное стирание данных стоит ждать тогда, когда на диск будет записано число данных, равное количеству свободного места + объём резерва (примерно 4 ГБ для 60 ГБ SSD). Если файл попадёт на «изношенную» ячейку, контроллер ещё не скоро перезапишет её новыми данными.
Восстановление данных с SSD-накопителей – достаточно трудоёмкий и долгий процесс, по сравнению с портативными flash-накопителями. Процесс поиска правильного порядка, объединения результатов и выбора необходимого сборщика (алгоритм/программа, полностью эмулирующая работу контроллера SSD-накопителя) для создания образа диска – нелёгкая задача.
Связано это в первую очередь с увеличением числа микросхем в составе SSD накопителя, что во много раз увеличивает число возможных вариантов действий на каждом этапе восстановления данных, каждое из которых требует проверки и специализированных знаний. Также в силу того, что к SSD предъявляются значительно более жёсткие требования по всем характеристикам (надёжность, быстродействие и т. д.), чем к мобильным флэш-накопителям, технологии и методики работы с данными, применяемые в них, достаточно сложны, что требует индивидуального подхода к каждому решению и наличия специализированных инструментов и знаний.
7 924
SSD (Solid State Drive) - это устройство хранения данных, которое использует память NAND flash для сохранения информации.
Основные принципы работы SSD:
Накопление данных в ячейках памяти NAND:
• В основе SSD лежит NAND-флэш-память, которая состоит из ячеек памяти. Эти ячейки могут хранить информацию в виде электрических зарядов.
• В зависимости от типа NAND-памяти (например, SLC, MLC, TLC, QLC), каждая ячейка может хранить один или несколько бит информации.
Блоки, страницы и циклы:
• Данные в NAND-памяти организованы в блоках, которые делятся на страницы. Блоки являются минимальной единицей для операций записи и стирания.
• Запись происходит на уровне страниц, но стирание осуществляется на уровне блоков. Это приводит к тому, что перед записью новых данных необходимо стереть целый блок, что увеличивает износ ячеек памяти.
Контроллер:
• SSD оборудован контроллером, который управляет операциями чтения, записи и стирания данных.
• Контроллер также отвечает за управление износом ячеек памяти, используя технологии, такие как TRIM, wear leveling и garbage collection.
Wear Leveling:
• Износ ячеек памяти при многократных операциях записи может быть неравномерным. Технология wear leveling используется для равномерного распределения износа по всем блокам, увеличивая таким образом срок службы SSD.
TRIM:
• Операционные системы, поддерживающие технологию TRIM, сообщают SSD, какие блоки данных больше не используются. Это помогает контроллеру оптимизировать процессы стирания и записи, улучшая производительность.
"Сборка мусора" (Garbage Collection):
• После того как данные удаляются, остаются "мусорные" блоки, которые нужно стереть перед записью новых данных. Сборка мусора - это процесс, который осуществляет контроллер для оптимизации пространства и улучшения производительности.
В результате этих принципов SSD обеспечивает более быстрый доступ к данным, чем традиционные механические жесткие диски, и имеет преимущества в плане надежности, энергопотребления и компактности.
7 924
Arduino - это открытая платформа для создания прототипов электронных устройств.
Несколько популярных моделей плат Arduino:
Arduino Uno: Это одна из самых популярных моделей. Она имеет микроконтроллер ATmega328P и набор входов/выходов для подключения различных датчиков и устройств.
Arduino Mega: Предназначена для проектов, требующих большего количества входов/выходов. Она оборудована микроконтроллером ATmega2560.
Arduino Nano: Компактная версия Arduino Uno, предназначенная для проектов, где важен небольшой размер. Она также оснащена микроконтроллером ATmega328P.
Arduino Due: Эта плата оснащена микроконтроллером SAM3X8E на базе архитектуры ARM Cortex-M3. Она предоставляет больше ресурсов для более сложных проектов.
Arduino Leonardo: Эта модель оснащена микроконтроллером ATmega32u4 и имеет встроенную поддержку USB, что делает ее подходящей для проектов, требующих взаимодействия с компьютером.
Arduino Pro Mini: Компактная и урезанная версия Arduino Uno, предназначенная для проектов, где важен небольшой размер и нет необходимости в множестве входов/выходов.
Arduino MKR серия: Это семейство плат, разработанных специально для интернета вещей (IoT). Они оборудованы различными средствами связи, такими как Wi-Fi, Bluetooth, и LoRa.
7 924
Обзор моделей Raspberry Pi:
Raspberry Pi 1 Model A и Model B:
• Raspberry Pi 1 Model A: 256 МБ оперативной памяти, один порт USB.
• Raspberry Pi 1 Model B: 512 МБ оперативной памяти, два порта USB.
Raspberry Pi 2 Model B:
• 1 ГБ оперативной памяти, четыре порта USB, более мощный процессор.
Raspberry Pi 3 Model B и Model B+:
• Raspberry Pi 3 Model B: 1 ГБ оперативной памяти, четыре порта USB, встроенный модуль Bluetooth и Wi-Fi.
• Raspberry Pi 3 Model B+: улучшенная версия с более высокими тактовыми частотами, улучшенной сетевой поддержкой и другими улучшениями.
Raspberry Pi 4 Model B:
• Доступны версии с 2, 4, или 8 ГБ оперативной памяти.
• Четыре порта USB 3.0, два порта USB 2.0, два порта micro-HDMI, более мощный процессор и графический процессор, поддержка двух мониторов, гигабитный Ethernet, поддержка 4K-видео и другие улучшения.
Raspberry Pi Zero и Raspberry Pi Zero W:
• Крайне компактные и доступные модели, предназначенные для проектов с ограниченными ресурсами.
Кроме того, у Raspberry Pi существует множество различных модулей и дополнений (HATs), которые позволяют расширять функциональность устройства.
اکنون در دسترس! پژوهش تلگرام ۲۰۲۵ — مهمترین بینشهای سال 
