Форум программистов, компьютерный форум, киберфорум
Бета-тестирование
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14

C#.NStar

22.11.2020, 01:26. Показов 33936. Ответов 523
Метки нет (Все метки)

С чего всё началось
Мой язык программирования развивается, в очередной раз меняя название. Пятое название после C↑ᶜC, C#++, C with stations и временного Unnamed2 имеет вид "C# .NStar". Это название не вызывает никаких ассоциаций со стрелками, с "симбиозом плюсов и шарпа", со "станционным программированием", а вызывает единственную - то, что этот язык - прямое продолжение C#. Теперь вы убедились, что этот язык - не пустая болтовня, одна версия уже увидела свет, поэтому надеюсь, что очередная презентация возможностей C# .NStar хоть и подвергнется критике, но не приведет ни к чему плохому. Вот что уже работает:
1. Пространства имен.
2. Ошибки списком строк - теперь отображение n ошибок не займет время, пропорциональное n2, и вообще я по максимуму убрал конкатенацию строк в цикле, что является экстремально важным признаком качества языка.
3. Списки - не только возврат списка, но и переменные списочных типов.
4. Индексы - последний и самый сложный из перечисленных пунктов. Такой код успешно работает:
Code
1
2
list(3) int a = (((1, 2, 3), (4, 5, 6), (7, 8, 9)), ((10, 11, 12), (13, 14, 15), (16, 17, 18)), ((19, 20, 21), (22, 23, 24), (25, 26, 27)));
return a[1, 2, 3];
Но для того, чтобы выложить версию, этого мало. Это просто презентация.
А вот несколько будущих возможностей:
1. Оператор switch с лямбда-выражением. Это невероятно мощная конструкция! Позволит убрать очень много дублирования в условиях. Вот два примера:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
if (task.StartsWith("Class "))
{
    return Action1(task.Substring("Class ".Length));
}
else if (task.StartsWith("Interface "))
{
    return Action2(task.Substring("Interface ".Length));
}
else if (task.StartsWith("Function "))
{
    return Action3(task.Substring("Function ".Length));
}
else if (task.StartsWith("Extent "))
{
    return Action4(task.Substring("Extent ".Length));
}
...
Code
1
2
3
4
5
6
7
8
return x => task == x + string s switch
{
    "Class " => Action1(s);
    "Interface " => Action2(s);
    "Function " => Action3(s);
    "Extent " => Action4(s);
    ...
};
Прошу обратить особое внимание на огромную мощь этой конструкции и написать, хотели бы вы ею воспользоваться или нет, и если нет, то почему.
2. Способ задания словаря будет отличаться от способа задания двумерного списка: ключ и значение будут разделяться оператором ":", а если словарь состоит из единственного элемента, доступного по всем ключам - достаточно указать один этот элемент. Пример:
Code
1
2
Dictionary[string, int] dic1 = ("Съешь": 1, "же": 2, "ещё": 3, "этих": 4, "мягких": 5, "французских": 6, "булок": 7, "да": 8, "выпей": 9, "чаю": 10, _: 0);
Dictionary[string, int] dic2 = -12345;
3. Оператор ![], позволяющий сменить внутренний тип коллекции без смены внешнего типа. Это позволит создать аналог LINQ нового поколения - Jaretorant, в котором не надо завершать каждое выражение функциями ToArray() или ToList(). Только посмотрите:
Code
1
2
3
4
() int oldList;
() real newList = oldList.TransformEach(x => 1r / x);
LinkedList[int] oldList2;
LinkedList[real] newList2 = oldList2.TransformEach(x => 1r / x);
А сама конструкция TransformEach записывается таким способом:
Code
1
2
3
4
5
6
7
8
9
10
Dictionary[(typename TSource, typename TCollection : IEnumerable[TSource], typename TDest), TCollection![TDest] Extent(TCollection source, Func[TDest, TSource] Transformator)] =
{
    TCollection![TDest] output = new TDest[source.Count()];
    int i = 0;
    for (TSource elem in source)
    {
        output[i++] = Transformator(elem);
    }
    return output;
}
P. S. Недавно я наткнулся на список торговых знаков Microsoft. Оказывается, там написано, что нельзя искажать, модифицировать или комбинировать с любыми словами, символами, изображениями или другими видами информации любые из этих торговых знаков. Но самих знаков немного: само слово "Microsoft", Windows, MSN, Bing, Skype, Microsoft Edge и еще один или два. C# там нет! Поэтому создать язык с названием C# .NStar мне ничего не мешает.


 Комментарий модератора 
Update от 09.02.2026


ПОБЕДА!!! C#.NStar достиг версии (Alpha RC) 0.9! Это первое приложение от Red-Star-Soft, когда-либо достигавшее подобной версии! (Фреймворк - это не приложение.) Теперь, надеюсь, я перестал быть "профессиональным недоделывателем"? И, надеюсь, я получу тест?
1. Работа с файлами.
2. При техническом крахе сохраняется лог во временную папку.
3. Потоки. Причем нет этого ужасного разбиения на две воюющих стороны - синхронные и асинхронные - переключение контекста происходит автоматически.
4. "Швейцарский нож" (оператор is, сопоставление шаблонов). Пока что реализованы семь шаблонов: константа, тип, тип с объявлением переменной, var с объявлением переменной, шаблон сравнения (больше/меньше), пустой шаблон (_) и составной шаблон - несколько шаблонов, объединенных операторами and, or, not. Есть одна замеченная, но не исправленная ошибка, что попытка применить шаблон сравнения не к числу вызывает технический крах. Возможно, в будущем исправлю.
5. Сокращенный оператор for - можно написать так:
Code
1
2
3
4
for (i in collection)
{
    ...
}
- или так:
Code
1
2
3
4
for (i in a..b)
{
    ...
}
6. Сокращенные константы - если есть ключевое слово const, необзательно писать var или тем более полный тип.
7. Записи (Record - с прописной буквы). В отличие от C#.NET, это по терминологии Мартина чистые структуры данных, имеющие свойства, совпадащие по именам и типам с параметрами, конструктор из эих параметров и стандартные методы Equals и GetHashCode и неспособные иметь другие методы и свойства.
8. Структуры (Struct - с прописной буквы).
9. Прототип полиморфизма в виде словарей от рекурсивного типа к классу, одним из следующих способов (ключевое слово Class в случае полиморфизма обязтельно брать в скобки):
Code
1
2
3
4
const [typename T, (Class)] ClassName = new(
{
    ...
});
Code
1
2
3
4
const ClassName = new [typename T, (Class)](
{
    ...
});
Code
1
2
3
4
const var ClassName = new [typename T, (Class)](
{
    ...
});
Code
1
2
3
4
const [typename T, (Class)] ClassName = new [typename T, (Class)](
{
    ...
});
Code
1
2
3
4
const [typename T : BaseType, (Class : BaseType2)] ClassName = new(
{
    ...
});
Code
1
2
3
4
const ClassName = new [typename T : BaseType, (Class : BaseType2)](
{
    ...
});
Code
1
2
3
4
const var ClassName = new [typename T : BaseType, (Class : BaseType2)](
{
    ...
});
Code
1
2
3
4
const [typename T : BaseType, (Class : BaseType2)] ClassName = new [typename T : BaseType, (Class : BaseType2)](
{
    ...
});
Словари от чисел, строк или других типов, кроме typename, пока лучше даже не пытаться создавать - они не работают!
10. Обработка исключений:
Code
1
2
3
4
5
6
7
8
try
{
    ...
}
catch (ExceptionType var) if (condition) // if, а не when
{
    ...
}
В текущей версии доступен базовый набор исключений: Exception, ArgumentException (включает в себя ArgumentNullException и ArgumentOutOfRangeException, хотя явно указать их нельзя), IndexOutOfRangeException, InvalidOperationException, NullReferenceException и IOException.
11. И самое невероятное - ПАКЕТНЫЙ МЕНЕДЖЕР!!! Вы можете подключить любой пакет, доступный в публичном репозитории NuGet - достаточно зайти в настройки и указать его имя.
Рабочие примеры кода на C#.NStar, в дополнение к предыдущим версиям:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
using System;
using System.Threading;
Class MyClass
{
    Constructor()
    {
    }
    int Function Sync()
    {
        var x = MyClass2.MyFunc(5);
        return x;
    }
    Task[int] Function Async1()
    {
        var x = MyClass2.MyFunc(5);
        return x;
    }
    Task[int] Function Async2(int n)
    {
        return n * n;
    }
}
 
static Class MyClass2
{
    Func[Task[int], int] MyFunc = new MyClass().Async2;
}
 
return new MyClass().Async1();
Code
1
2
3
object item = "Welcome!";
if (item is string text)
    return text;
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
abstract Class BaseStack
{
    required typename T { get, init };
    
    abstract T Function Peek();
    abstract T Function Pop();
    abstract null Function Push(T item);
}
 
const [typename T, (Class : BaseStack[T])] Stack = new(
{
    private () T list = new(32);
 
    T Function Peek()
    {
        return list[^1];
    }
 
    T Function Pop
    {
        return list.GetAndRemove(list.Length - 1);
    }
 
    null Function Push(T item)
    {
        list.Add(item);
    }
});
 
BaseStack[int] intStack = new Stack[int]();
intStack.Push(5);
intStack.Push(10);
var x = (intStack.Pop(), intStack.Peek());
BaseStack[string] stringStack = new Stack[string]();
stringStack.Push("A");
stringStack.Push("B");
var y = (stringStack.Pop(), stringStack.Peek());
return (x, y);
Code
1
2
3
4
5
6
() int list = new();
for (i in Chain(0, 10)) while (i * i % 20 < 10)
{
    list.Add(i);
}
return list;
Code
1
2
3
4
5
6
int n = 0;
for (i in 1..1000)
{
    n++;
}
return n;
Code
1
2
3
Record Pair(string Name, int Value);
Pair pair = new("Status", 100);
return pair;
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
const [typename T : IComparable[T], (Class)] Repository = new(
{
    private () T items = new();
 
    null Function Add(T item)
    {
        items.Add(item);
    }
 
    T Function GetMax()
    {
        if (items.Length == 0)
            return null;
        return Max(items);
    }
});
 
Class Product : IComparable[Product]
{
    int Id;
    int Function CompareTo(Product product)
    {
        return Id.CompareTo(product.Id);
    }
}
 
var repo = new Repository[Product]();
repo.Add(new Product[1]());
repo.Add(new Product[5]());
return repo.GetMax().Id;
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
using System;
using System.IO;
try
{
    () int list = (1, 2, 3);
    return list.IndexOf(1, 5);
}
catch (ex) if (ex is not ArgumentException)
{
    return 1;
}
catch (ex)
{
    return "" + ex.Message;
}
return 2;
P. S. Можно также скачать из облаков, ссылка на странице версии.
1
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.11.2020, 01:26
Ответы с готовыми решениями:

Мелкомягкие мыслят местами точно как и я или следят за моим компьютером и крадут идеи, записанные на нем для C# .NStar?
Кто знает? Вот неполная цитата из файла, созданного в феврале этого года: А тут оказывается, что...

Стал ли .NStar в меньшей степени "сборной солянкой"?
sau, это тема для вас! Хотя обоснованные, не содержащие трёпа и троллинга мнения других...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
523
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 01:24  [ТС]
Билд восьмой, масштабный. Исправлена ошибка с перетаскиванием в окне кода. C#.NStar уже частично использует фреймворк .NStar: можно создать переменные типов BaseDictionary[TKey, TValue, TCertain] и его подтипов Dictionary[TKey, TValue] и SortedDictionary[TKey, TValue]; BaseList[T, TCertain] и его подтипов BaseHashSet[T, TCertain], BaseSet[T, TCertain], BaseSumList[T, TCertain], BitList, Buffer[T], ListHashSet[T], NList[T], SumList, а возможно, и других, все не сосчитать. Все эти типы доступны в пространстве имен System.Collections, которое теперь можно подключить через using. Работают методы BaseDictionary.Remove(), BaseDictionary.TryAdd(), BaseList.Add(), BaseList.Clear(), BaseList.Contains(), BaseList.GetRange(), BaseList.IndexOf(), BaseList.Insert(), BaseList.Remove(), BaseList.RemoveAt(), BaseList.RemoveValue() и BaseList.TrimExcess(). Пока что не работает BaseDictionary.Add() (используйте TryAdd()). Также язык теперь автоматически определяет тип самого внутреннего списка при переводе list(n) T: List<T>, NList<T> или BitList.
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 17:59  [ТС]
Билд девятый, финальный. Добавлены делегаты как параметры функции, теперь можно реализовывать аналог LINQ, но каждую функцию конверсии пока что придется объявлять явно, без лямбда-выражений. Добавлено корректное сообщение об ошибке при попытке вставить присваивающий оператор справа от неприсваивающего в одном выражении. Исправлены также методы BaseList.LastIndexOf(), BaseList.RemoveEnd() и BaseList.Reverse().
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 18:28  [ТС]
Welemir1, теперь язык стал лучше? Или чего еще не хватает, чтобы стал?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18331 / 14257 / 5370
Регистрация: 17.03.2014
Сообщений: 28,923
Записей в блоге: 1
06.02.2025, 18:35
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
теперь язык стал лучше? Или чего еще не хватает, чтобы стал?
В чем смысл этого вопроса если тема про альфа версию языка? У вас нет плана развития языка?
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 18:37  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
У вас нет плана развития языка?
Есть план, например, на наследование, но это нетривиальная задача.
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,696
Записей в блоге: 29
06.02.2025, 19:25
Etyuhibosecyu, увы, нет. Это не ЯП, это некое графическое приложение, которое позволяет в окошке писать функции по странному синтаксису. Для ЯП нужна документация, тип файла свой, компилятор/интерпретатор, возможность запуска своего файла с кодом, REPL в консоли с хелпом, гайды по написанию простых программ.

Добавлено через 1 минуту
а главное -цель! для чего он создан и что решает лучше других

Добавлено через 35 секунд
ты возьми для пример а любой новый ЯП и посмотри их сайтик и доку, например Gleam, сразу ясен и синтаксис и цель/причина создания
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 19:32  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
документация
Ссылка на одной из предыдущих страниц.
Цитата Сообщение от Welemir1 Посмотреть сообщение
компилятор/интерпретатор
Транспайлер не подходит?
Цитата Сообщение от Welemir1 Посмотреть сообщение
гайды по написанию простых программ
Ссылка.
Цитата Сообщение от Welemir1 Посмотреть сообщение
а главное -цель! для чего он создан и что решает лучше других
Цель - язык общего назначения. Для системного программирования, такого как ОС и драйвера, не подходит, для остального подходит.
0
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 290
06.02.2025, 19:36
Цель - язык общего назначения. Для системного программирования, такого как ОС и драйвера, не подходит, для остального подходит.
Etyuhibosecyu, и что же можно сделать с Вашим ЯП, если запускать его можно исключительно одним файлом в окошке графического приложения?
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 19:38  [ТС]
-_human_-, ну это же тестовая версия...
0
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 290
06.02.2025, 19:40
Etyuhibosecyu, ну так какой смысл был изначально делать графику, если гораздо осмысленней в виде консольной утилиты?
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 19:42  [ТС]
Цитата Сообщение от -_human_- Посмотреть сообщение
в виде консольной утилиты?
А разве в консоли можно вводить многострочный код, не вызывая после каждого перевода строки срабатывание?
0
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 290
06.02.2025, 19:44
Etyuhibosecyu, посмотрите как работает интерактивная консоль Питон. + зачем код вводить в консоли?? Просто на вход подается файл с кодом.
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,696
Записей в блоге: 29
06.02.2025, 20:32
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
А разве в консоли можно вводить многострочный код
да. Но дело не в этом, а в том, что ты не хочешь никого слушать и гнешь свою линию

ЯП твой для чего, ради самого написания чтоли? Я тебе пример указал, но ты не пошел читать, попробую разжевать - твой язык, быстрее, лучше, читаемей, короче чем остальные? Он решает какие то задачи лучше других ЯП? если нет то удаляй, он никому не нужен.
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 22:12  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
быстрее
Чем Python - да.
Цитата Сообщение от Welemir1 Посмотреть сообщение
читаемей, короче
В некоторых случаях да.
Цитата Сообщение от Welemir1 Посмотреть сообщение
Он решает какие то задачи лучше других ЯП?
Уже писал про рекурсивные функции, McEliece и конкатенацию строк.
0
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 290
06.02.2025, 22:19
Etyuhibosecyu, питон - ЯП с динамической типизацией, огромной базой готовых библиотек и длинной историей, т.е. его отшлифовывали уже кучу времени. Сомневаюсь, что Ваш язык хоть какой-то конкурент питону в тех областях, где его обычно применяют.
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 22:21  [ТС]
Цитата Сообщение от -_human_- Посмотреть сообщение
Сомневаюсь, что Ваш язык хоть какой-то конкурент питону в тех областях, где его обычно применяют.
Да, мой язык не кроссплатформенный батник, а серьезный.
0
78 / 73 / 19
Регистрация: 18.05.2021
Сообщений: 290
06.02.2025, 22:24
Поэтому полезности никакой в нем нет, это и так понятно, если Вам нужно, чтоб он использовался кем-то помимо Вас, то должно быть что-то что отличает в выгодную сторону от остальных языков, не внося чрезмерного количества дополнительных минусов. На данный момент их нет. Но, с другой стороны, если просто хочется сделать свой ЯП и все, то в целом-то какая разница есть ли в нем практический смысл.

Добавлено через 3 минуты
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
кроссплатформенный батник
Кроссплатформенность это ну совсем не минус. Питон уж точно не "батник", на это максимум потянет условный lua, интерпретатор которого в целом куда угодно впихнуть можно (что опять таки плюс, то чем он выгодно отличается от конкурентов.)
Ваш же язык "средненький", он не выделяется ни чем (кроме того, что пока в нем мало что работает)
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
363 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,812
Записей в блоге: 14
06.02.2025, 22:30  [ТС]
Цитата Сообщение от -_human_- Посмотреть сообщение
Питон уж точно не "батник"
А народ пишет, это не реклама, не пропаганда, это мнение народа, что - есть батник, потом поступает требование переписать под Bash в Linux, и работник думает: а потом захотят выпустить еще под какую-то ОС, снова переписывать, а бывают ли кроссплатформенные батники? Ответ: бывают, это Python. На большее, чем простые скрипты, аналогичные батникам, его используют крайне редко. Еще раз - это не я придумал, это мнение народа.
0
282 / 485 / 12
Регистрация: 21.06.2019
Сообщений: 3,020
07.02.2025, 06:12
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
А народ пишет, это не реклама, не пропаганда, это мнение народа, что - есть батник, потом поступает требование переписать под Bash в Linux, и работник думает: а потом захотят выпустить еще под какую-то ОС, снова переписывать, а бывают ли кроссплатформенные батники? Ответ: бывают, это Python. На большее, чем простые скрипты, аналогичные батникам, его используют крайне редко. Еще раз - это не я придумал, это мнение народа.
Не знаю, что за народ тебе это сказал, но на питоне пишут сервисы с миллионами пользователей в сутки. На твоем же языке пока не написано ничего. Так что кто тут серьёзный а кто нет, думаю, всем очевидно.

Добавлено через 5 минут
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
Уже писал про рекурсивные функции
Есть в любом функциональном языке. Scala например.
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
конкатенацию строк
Это мы уже выяснили, что тоже есть в любом языке, включая сишарп. В котором у тебя 15 лет опыта, а про StringBuilder так и не узнал
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,696
Записей в блоге: 29
07.02.2025, 07:05
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
А народ пишет
у меня идея! вот этому народу который тебе глупости пишет и предложи свой ЯП, они явно мало что понимают в программировании

так какие конкретные причину у любого человека выбрать твой ЯП вместо сишарпа и джавы?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ответ Создать тему
Новые блоги и статьи
[golang] Worker Pool
alhaos 09.06.2026
Worker Pool Worker Pool — паттерн конкурентной обработки задач в Go. Суть: фиксированное количество горутин-воркеров читают задачи из общего канала и пишут результаты в общий канал результатов. . . .
[golang] Pipeline
alhaos 08.06.2026
Pipeline Pipeline — паттерн конкурентной обработки данных в Go. Суть: данные проходят через цепочку независимых стадий, каждая из которых работает в своей горутине и общается с соседями через. . .
Свет внутри себя
kumehtar 07.06.2026
Пусть это будет здесь lIs4oanZS9Y
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru