Media is too big
VIEW IN TELEGRAM
Бывший разработчик Unity продемонстрировал собственную анимационную систему, которая эффективнее Unity в 14 раз
С демо:
Unity демо:
Credits:
В вики имеется подборка книг по разным топикам программирования и компьютерной графике.
Рекомендуется к изучению.
#unity #animation #gamedev #cpp #lifeexexe #lifeexecode
Please open Telegram to view this post
VIEW IN TELEGRAM
1 21👏13😁8🔥2 2❤1🏆1
Хорошая бесплатная книга по стандартным алгоритмам. Идеально подходит как справочник:
PDF-версия доступна в README или в релизах:
TArray,
TMap,
TSet,
TList.
Это проприетарные контейнеры, оптимизированные под систему памяти, Garbage Collector и рефлексию UE.В статье на примерах рассматриваем предикаты и проекции (способ указать алгоритму, по какому полю объекта нужно выполнять операцию).
Patreon | Boosty | PayPal
GitHub | Itch | X | Wiki | LifeEXE School
#lifeexe #lifeexecode #unrealengine #ue5 #cpp #stl
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥29 12 5❤2👍2🦄1
This media is not supported in your browser
VIEW IN TELEGRAM
Небольшая статья по созданию симуляции океана на основе модели Тессендорфа
Автор пошагово разбирает весь процесс — от теории до практической реализации:
C++/HLSL
#learn #ocean #theory #cpp #hlsl #gamedev #lifeexe #lifeexecode
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥35❤7 6👍3🦄1 1
Вышел бесплатный open-source плагин для Unreal Engine, который позволяет распределять «тяжёлые» задачи на несколько кадров
GWB не делает задачи асинхронными и не переносит их в другие потоки — они выполняются в основном игровом потоке, просто распределяются по кадрам (time-slicing).
Если стоит задача не раздробить вычисления, а управлять операциями, требующими ожидания, то имеется другой плагин для написания асинхронного кода
Плагин добавляет в движок полноценную поддержку
C++20
корутин #gameplay_work_balancer #gwb #ue5coro #plugin #free #coroutine #cpp #unrealengine #ue5 #gamedev #lifeexe #lifeexecode
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥34 14🦄4❤1
В эфире рубрика выходного дня: Воскресный C++
Numeric limits в стандарте C++ и в Unreal Engine
На Boosty и Patreon расширенная статья с множеством интерактивных примеров в Compiler Explorer
std::numeric_limits
в C++ — это стандартный шаблонный класс, который предоставляет информацию о свойствах числовых типов, например:infinity,
quiet_NaN,
signaling_NaN
и другие.Полная спецификация на cppreference.com
Простейший пример использования:
#include <limits>
#include <print> // C++23
int main()
{
std::println("Max int: {}", std::numeric_limits<int>::max());
std::println("Min double: {}", std::numeric_limits<double>::min());
std::println("Lowest float: {}", std::numeric_limits<float>::lowest());
std::println("Double epsilon: {}", std::numeric_limits<double>::epsilon());
return EXIT_SUCCESS;
}
Ключевые особенности
Безопасность
Вместо «магических чисел» (например,
2147483647
для int
), вы используете std::numeric_limits<int>::max()
. В итоге код становится более читаемым и переносимым (платформонезависимым).Портируемость
int,
float,
double, uint64_t
, а также с пользовательскими числовыми типами, если для них существует специализация шаблона numeric_limits
.Чистота кода
Когда реально нужен
NaN
.В Unreal Engine имеется собственный шаблон
TNumericLimits<T>
— это аналог std::numeric_limits
, реализованный в движке. Заголовочный файл находится по адресу:
Runtime/Core/Public/Limits.h
Применение абсолютно аналогичное, как и в стандартном C++:
#include "Math/NumericLimits.h"
#include "Logging/StructuredLog.h"
DEFINE_LOG_CATEGORY_STATIC(LogNumLimitsTest, All, All);
void NumLimitsTest()
{
const int32 MaxInt = TNumericLimits<int32>::Max();
const int32 MinInt = TNumericLimits<int32>::Min();
const float MaxFloat = TNumericLimits<float>::Max();
const float MinFloat = TNumericLimits<float>::Min();
UE_LOGFMT(LogNumLimitsTest, Display, "Int32: Min={0}, Max={1}", MinInt, MaxInt);
UE_LOGFMT(LogNumLimitsTest, Display, "Float: Min={0}, Max={1}", MinFloat, MaxFloat);
}
std::numeric_limits
— читаем раздел Use of standard libraries. Поэтому можно выбирать любой подходящий под вашу конкретную ситуацию шаблон.Всем чистого кода
Patreon | Boosty | PayPal
GitHub | X | LifeEXE School | Itch | Wiki | Курс по UE
#code #cpp #code_hints #lifeexeEDU #unrealengine #ue5 #gamedev #lifeexe #lifeexecode #best_practice #numeric_limits #clean_code
Please open Telegram to view this post
VIEW IN TELEGRAM
6🔥24 16❤9 2🦄1
В эфире рубрика выходного дня: Воскресный C++
Написал большую статью на тему:
«Asserts в стандарте C++ и в Unreal Engine»
❗️ На Boosty и Patreon полная версия с множеством примеров!
По традиции сначала разбираем как все работает на чистом
C++, а потом смотрим, что происходит в Unreal Engine.
Assertions — это утверждения, проверяющие предположения программиста о корректности кода. Они помогают выявлять ошибки и документировать инварианты.
Инвариант — это условие, которое должно быть истинным всегда в определённом контексте.
Зачем нужны assertions?
Виды assertions
В стандартном C++ основной инструмент для реализации утверждений — это макрос препроцессора
assert
, определенный в заголовочном файле <cassert>
:stderr
и немедленно завершает программу путем вызова функции std::abort()
double div(double numerator, double denominator)
{
assert(denominator != 0.0);
return numerator / denominator;
}
Стандартный макрос
assert
не имеет встроенного параметра для пользовательских сообщений. Однако существуют две распространенные идиомы для добавления диагностики, которая будет выведена в диагностическом сообщении в случае сбоя assert(divisor != 0 && "Divisor cannot be 0");
assert(("Divisor cannot be 0", divisor != 0));
Распространенная ошибка при использовании
assert
— это включение в проверяемое выражение кода с побочными эффектами. Проблема в том, что когда определен макрос
NDEBUG
, все выражение внутри assert
удаляется из кода. Это может привести к тому, что логика программы в отладочной и релизной сборках будет отличаться. assert(InitializeSubsystem());
[[maybe_unused]] const bool bSuccess = InitializeSubsystem();
assert(bSuccess);
Unreal Engine расширяет стандартный макрос
assert
, добавляя дополнительные возможности к рантайм проверкам, Имеются следующие семейства: check
, verify
, ensure
.Семейство
check
является прямым эквивалентом стандартного assert
в Unreal Engine. Сбой check
указывает на критическую ошибку в программе, и выполнение немедленно останавливается void AMyActor::CalculateJumpVelocity(AActor* JumpTarget, FVector& JumpVelocity)
{
check(JumpTarget != nullptr);
}
Остальные макросы данного семейства:
check, checkf, checkSlow, checkfSlow, checkCode, checkNoEntry, checkNoReentry, checkNoRecursion, unimplemented
Следующее семейство макросов является решением проблемы побочных эффектов. Выражение внутри макроса
verify
выполняется всегда, независимо от конфигурации сборки.Полный список макросов:
verify, verifyf, verifySlow
Данное семейство макросов используется для сообщения о нефатальных ошибках. Программа не завершает работу, а отправляет отчет со стеком вызовов в Crash Reporter и продолжает выполнение:
ensure, ensureAlways, ensureMsgf, ensureAlwaysMsgf
static_assert
check
verify
checkSlow
ensure
checkNoEntry
или unimplemented
checkNoRecursion
checkNoReentry
В статье на Boosty и Patreon подробнее про каждый из макросов и static_assert
Всем чистого кода
Patreon | Boosty | PayPal
GitHub | X | LifeEXE School | Itch | Wiki | Курс по UE
#code #cpp #code_hints #lifeexeEDU #unrealengine #ue5 #gamedev #lifeexe #lifeexecode #best_practice #assert #clean_code
Please open Telegram to view this post
VIEW IN TELEGRAM
21🔥38 10👍9❤5🦄1 1
Поздравляю с началом нового учебного года!
Забирайте бесплатный купон на 100 мест на мой курс «Unreal Engine — полное руководство по разработке на С++»
Статистика по курсу на сегодня следующая
Студенты из
Всем спасибо за отзывы и прохождение!
Patreon | Boosty | PayPal
GitHub | X | LifeEXE School | Itch | Wiki | Курс по UE
#code #cpp #lifeexeEDU #unrealengine #ue5 #gamedev #lifeexe #lifeexecode #udemy #course #shooter #free #coupon
Please open Telegram to view this post
VIEW IN TELEGRAM
Udemy
Unreal Engine — полное руководство по разработке на С++
Раскройте возможности C++ для разработки игр в Unreal Engine
🔥76❤21 6❤🔥3⚡2🦄1 1
Детей без присмотра не оставляем
#пятничное #friday #cpp #unrealengine #ue5 #gamedev #lifeexe #lifeexecode #meme #humor
Please open Telegram to view this post
VIEW IN TELEGRAM
😁37 15 6❤2🦄1
This media is not supported in your browser
VIEW IN TELEGRAM
Вышла
Visual Studio 2026 Insiders
— так теперь называется preview сборка. Скачать бесплатную Community версию можно по ссылке Внутри:
Подробнее можно почитать в блоге
и также в тему
#vs #code #cpp #gamedev #lifeexe #lifeexecode
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥23❤9👍6🦄1 1
С днём программиста всех причастных!
И да.. стандарт
#day256 #code #cpp #programmer_day #gamedev #lifeexe #lifeexecode #humor
Please open Telegram to view this post
VIEW IN TELEGRAM
❤30😁26🔥9🎉8🤯4👍3 3🦄2
Media is too big
VIEW IN TELEGRAM
В новый Unreal Engine 5.7 завезли ИИ ассистента — плагин AIAssistant, который находится по адресу:
Engine\Plugins\Experimental\AIAssistant
Плагин элементарный: он просто открывает веб-морду Epic Developer Assistant в отдельном окне редактора движка, и, кстати, работает без логина:
Всё выглядит так, что разработчики, создавая плагин для интеллекта искусственного решили пренебречь интеллектом естественным.
Лапидарно — несколько моментов, которые прямо бросаются в глаза
TSet
в простейшем случае для 14 символов? Возможно, конечно автор изучал структуры данных на данном коде — кто знает:FString FAIAssistantConfig::GetMainUrlAsRegexString() const
{
static const TSet<FString::ElementType> CharactersToEscape{
'.', '*', '+', '?', '(', ')', '[', ']', '{', '}', '^', '$', '|', '\\',
};
FString Escaped;
Escaped.Reserve((MainUrl.Len() * 2) + 2 /* Allow for regex anchors */);
Escaped += FString::ElementType('^');
for (const FString::ElementType Character : MainUrl)
{
if (CharactersToEscape.Contains(Character))
{
Escaped += FString::ElementType('\\');
}
Escaped += Character;
}
Escaped += FString::ElementType('$');
Escaped.Shrink();
return Escaped;
}
TSet
тут избыточен — создаётся хеш-таблица с бакетами и метаданными для всего нескольких статических символов. Хватит switch/if
или простейшей строки-набора:static const FString CharsToEsc = TEXT(".+*?()[]{}^$|\\");
FString::ElementType
в данном случае только усложняет читаемость — можно смело использовать TCHAR.
FString
имеет методы Append
и AppendChar
, которые аккуратно избавят от громоздких конструкций вида += FString::ElementType
Escaped += FString::ElementType('^');
Escaped.AppendChar('^');
GetMainUrlAsRegexString
привязана к классу. Очевидно, её можно освободить или оформить как часть библиотеки утилит, передавая MainUrl
параметром. Это разблокирует (помимо славы выдающегося архитектора ПО):IMPLEMENT_SIMPLE_AUTOMATION_TEST
, хотя Automation Spec
уже давно доступен. Ничего критичного, но зачем тянуть старое в новом плагине.Patreon | Boosty | PayPal
GitHub | X | LifeEXE School | Itch | Wiki | Курс по UE
#code #cpp #plugin #unrealengine #ue5 #gamedev #lifeexe #lifeexecode #ai #ai_assistant #tests #code_review
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥34 10🦄6 4❤2😁2⚡1👍1