Задать вопрос
  • Как разбить URL на сегменты и найти его соответсвующее имя?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    В .NET есть стандартный класс System.Uri
    Посмотрите, может вам хватит его возможностей?
    Ответ написан
    Комментировать
  • Как по другому сделать?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Вынесите описания переменных наверх, над swicth.
    int PlayerDamage ;
    int PlayerHealth;
    int PlayerResist ;
    
     switch(characterChoose)
     {
         case 0:
             PlayerDamage = 50;
             PlayerHealth = 150;
             PlayerResist = 25;
             break;
         case 1:
             PlayerDamage = 75;
             PlayerHealth = 125;
             PlayerResist = 15;
             break;
    
     }

    PS Согласен с предыдущим комментатором - инциализация через оператор switch выглядит тяжеловесно. В нынешнем C# можно записать то же самое сильно короче, через деконструкцию, например.
    PPS Держите пример с вашеми данными, как это должно выгдядеть стильно-модно-молодежно:
    int characterChoose = Convert.ToInt32(Console.ReadLine());
    (int PlayerDamage, int PlayerHealth , int PlayerResist)=characterChoose switch
    {
        0 => (50, 150, 25),
        1 => (75, 125, 15),
       //... дописать все остальные варианты
    } ;
    Ответ написан
    Комментировать
  • Как правильно сделать асинхронный генератор с неявным кол-вом выполнения?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Я долго думал над предыдущем ответом и понял почему вы его не пометили - при том, что он таки является ответом (и это очевидно: в нем кристалльно прозрачно (если конечно как следует подумать) сказано, что вы пытаетесь использовать неинициализованные переменные в операции деления внутри опреатора console.log, который у вас следует после yield).
    А подумав, я все же решил удовлетворить свою страсть к графомансву и разъяснить вам, почему смысл предыдущего ответа ответ столь очевиден - если хорошо и долго думать, естественно. Но если вам это и так явно, или вы уже все поправили, или для вас в этом разъяснении сликом много букв, то не читайте далше, а просто отметьте предыущий.

    Но раз уж вы до сюда читать дошли, продолжу. Как уже сказано в предыдущем ответе, имена этих неопределенных переменных - _page и _pages. И да, для JS это(внезапно) - уже другие переменные, нежели page и pages, которым вы что-то там присваиваете: в JS встроен слишком слабый AI, чтобы понять, что это - одно и то же, а символы подчеркивания надо игнорировать.
    Это переменным page и pages (без подчеркивания), а не _page и _pages вы таки присваиваете значения, хоть и немного поздновато: данные рассчитанные из этих значений, если бы у JS хватило ума догадаться, как должно быть, были бы выведены на консоль при следующем проходе цикла - что обязательно сбило бы вас с толку, если бы вы когда-нибудь обратили бы внимание на вывод в консоли - потому что данные относились бы не к тому циклу. Но так или иначе, если бы AI JS был получше (или вы бы использовали правильные имена переменных), то код бы в целом работал столько раз, сколько надо(хоть и вывел бы на консоль нечто страннное, впрочем, это уже фигня, да?).
    А так, из-за слабости AI JS, один-то раз у вас yield выполняется, потому что он все же до console.log. Но вот дальше из-за использования неинициализованных переменных будет выброшена ошибка. Да, эту ошибку ваш код успешно перехватывает и давит, но - уже вне цикла. И все - цикл завершен, и генератор с чистой совестью завершает свою работу.
    Ошибка же, в рамках моего скромного понимания, там должна там быть какой-то на тему работы с NaN (значение неинециализованной переменной - undefined - при преобразовании в число дает именно NaN). Мне это проверять лень (и вообще я программист ненастоящий), но вы, если вам это было бы любопытно, могли бы даже увидеть и тип, и сообщение об ошибке, если бы вместо того, чтобы давить ошибку с выводом неинформативного текста, вывели бы свойства name и message объекта ошибки (error.name и error.message в вашем случае). Этот совет - он, конечно, на случай, что вы желаете понимать, что там за ошибка. Но, может, вам надо просто убрать ее от юзера с глаз долой, чтобы не мозолила глаза -тогда указанные свойства выводить, конечно, незачем.
    Как это имеющееся положение поправить - это я вам не решусь советовать, не зная точно ваших намерений. Если вы хотите, как часто это делается в реальной разработке, замести ошибку под ковер, чтобы не оствечивала (что логично, если вам надо это заставить код работать хоть как-то) чтобы выполнить yield должное количество раз - просто перенесите оператор try/catch внутрь цикла. Кстати запомните этот прием: он обязательно пригодится вам при дальнейшей разработке костылей (правда следите при этом, чтобы цикл все-таки закончился, а то конфуз будет).
    Если же вы почему-то решили исправить ошибку, используйте, руководствуясь намеками из предыдущего ответа, правильные имена переменных.

    И обязательно пометьте предыдущий ответ: его автор нашел ошибку, о которой он аккуратно вам намекнул, раньше чем я даже просто прочитал ваш вопрос.
    Ответ написан
    Комментировать
  • Как применить настройки прокси-сервера через реестр в С#?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Браузеру надо сообщить, что настройки изменились парой вызовов процедуры InternetSetOption из WinInet.dll. Вызывать надо через P/Invoke На stackoverflow нашел пример, как это делать в Powershell.
    function Refresh-System
    {
      $signature = @'
    [DllImport("wininet.dll", SetLastError = true, CharSet=CharSet.Auto)]
    public static extern bool InternetSetOption(IntPtr hInternet, int dwOption, IntPtr lpBuffer, int dwBufferLength);
    '@
    
    $INTERNET_OPTION_SETTINGS_CHANGED   = 39
    $INTERNET_OPTION_REFRESH            = 37
    $type = Add-Type -MemberDefinition $signature -Name wininet -Namespace pinvoke -PassThru
    $a = $type::InternetSetOption(0, $INTERNET_OPTION_SETTINGS_CHANGED, 0, 0)
    $b = $type::InternetSetOption(0, $INTERNET_OPTION_REFRESH, 0, 0)
    return $a -and $b
    }

    Адаптируйте этот код к C# (пояснение: Add-Type в PS служит для загрузки сборки или неуправляемой DLL ). Или поищите по имени этой процедуры код на C#.
    Ответ написан
    5 комментариев
  • Почему импортированные функции не видят других импортированных функций?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Потому что у кажого импортированного модуля - своя область видимости переменных.
    Импортируйте getPageTitle в getHeader . А если же getPageTitle отдельно не используется, можете его реэкспортировать из getHeader, а в основном скрипте не импортировать вообще.
    Ответ написан
    Комментировать
  • Как в NTFS дать права на запись без права чтение и отображение?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    В разрешениях на папку (вкладка Security свойств, кнопка Advanced) установить разрешение "создать папку" для Authenticated users с областью действия только для этой папки и разрешение Full control (или Write, если не хотите, чтобы они там сами права раздавали) для CREATOR OWNER.
    Чтобы папки не могли видеть те, кому тутда доступа нет - включить Access based enumeration на вкладе Share ее свойств.
    Ответ написан
    Комментировать
  • Как определить принадлежность точки к плоскости?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    У вас нет проверки условий для диагональных границ области: y<=x при x<=1 и abs(y)<=x-1 при x>=1. Добавляйте, проверяйте и сдавайте решение.
    Ответ написан
    1 комментарий
  • Firefox - как зайти пол двумя разными аккаунтами, чтоб не было разлогина на одном?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    В Firefox есть штатное расширение для этого: Firefox Multi-Account Containers
    Ответ написан
    2 комментария
  • Как десериализовать простой Json в массив?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Используйте LINQ:
    Если поле code в типе, получаемом после десериализации имеет тип int (по уму должно быть так, но я с NewtonSoft JSON не работал, поэтому не уверен в таких подробностях), просто допишите к выражению для десериализации
    .Select(x=>x.code).ToArray();
    Если тип, паче чаяния, другой - преобразуйте результат, возвращаемый лямбда-функцией в Select к int (для строки это будет Int32.Parse(x.code)
    Ответ написан
    Комментировать
  • Как опубликовать программу?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Подключите нужные библиотеки времени выполнения (в вашем списке в комментарии к вопросу я других не вижу) статически: https://learn.microsoft.com/cpp/build/reference/md...

    PS А можете, как написал выше rPman, скачать и установить на целевом ПК нужный vcredist. И да, соберите свою программу в конфигурации Release - возможно, вам vcredist самому ставить и не понадобится, ибо он там уже есть (изначально или кто-то до вас поставил).
    Ответ написан
    Комментировать
  • Как подключить пользователей к серверу AD в другой подсети?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Проверьте (например, командой ping) на сервере AD разрешение имен DNS для сайтов, которые находятся в интернете. Если оно не работает - настройте так, чтобы оно работало. Как именно настроить - завист от причины. Например, если запросы DNS наружу от сервера AD режутся у вас на маршрутизаторе - разрешите их: сервер DNS на сервере AD по умолчанию уже настроен на поиск в DNS, начиная с корневых серверов, и дальше в соответствиеи с делегированием, а чтобы этот поиск работал, нужно чтобы запросы проходили.
    Если запросы DNS к посторонним серверам (кроме своего) режет провайдер - настройти на сервере DNS для AD в его свойствах безусловную пересылку на сервер DNS провайдера.
    Ответ написан
    Комментировать
  • Задваивается доменное имя в DNS запросе?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Я так понимаю у меня не находит сервис из-за задваивания "looch.local" в запросе.

    Наоборот, запрос к имени с к нему дописанным суффиксом домена ("задваивание") происходит потому, что перед этим на запрос к самому имени клиенту приходит ответ, что имя не найдено.

    Как я понял, у вас это 172.16.128.1 - это микротик? Если да, тогда подозреваю, что его адрес отдавается по DHCP клиентам в качестве второго сервера DNS, а на самом микротике условная пересылка запросов к домену AD DNS на контроллер домена AD (КД) не настроена. Так? Если так (это - распространенная ошибка), то либо уберите микротик из списка серверов DNS, либо настройте на нем нужную условную пересылку (если это возможно и если вы это умеете). Потому что клиент, в какой-то момент может переключиться на этот второй сервер DNS на микротике (например, при сбое при обращении к DNS на КД), а микротик ничего про ваш домен AD не знает - вот и получается эта ошибка.
    Ответ написан
  • 2 Exchange Server в разных лесах и 1 Outlook?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Немного теории по поводу отбойников с адресами, начинающимися на "IMCEAEX" Это - адеса формата X.500(содержимое атрибута legacyExchangeDN в каталоге), преобразованные в формат SMTP. Их наиболее вероятный источник - локальный кэш адресов Outlook, используемый при автозаполнении адреса (он запоминает адреса внутренних получателей именно в формате X.500). Такие ошибки могут встречаться и в рамках одного леса - если этот атрибут по каким-то причинам поменялся)
    Простейший способ борьбы: проинструктировать пользователей по получении такого отбойника выбрать нужный адрес из Голобальной адресной книги - это достаточно сделать один раз. Можно еще также в поле адреса в новом письме в Outlook начать набирать адрес, получить автозаполнение из кэша и удалить его (ЕМНИП - через локальное меню по правой кнопке).
    Можно ещё почистить кэш автозаполнения (в старых версиях он был в файлах .nk2 в папке Outlook, но, по слухам, в более новых версиях это могло поменяться).
    Ответ написан
    Комментировать
  • Как называется (термин) предельное число в счетной системе континуумного типа?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Вы про точную верхнюю грань последовательности (супремум)? Обозначается она символом sup.
    Ответ написан
    Комментировать
  • Как правильно и удобно читать данные из БД?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Думаю, что надо раскрыть подробнее тему предыдущих ответов и комментариев.
    Проблемы со сложностью у вас, потому что вы не используете современые средства .NET и C#.
    В .NET исторически сложилось несколько слоев API для обеспечения параллельной работы, и использование функций обратного выдова - самый старый и самый громздкий из них. А самый удобный и современный - это Task Parallel Library (TPL): он, плюс конструкции языка C# async/await, позволяет писать такой асинхронно выполняющийся код так, будто он выполняется синхронно.
    Скорее всего (я просто не уточнял, потому пишу так) для SQLite есть асинхронный API и для использования с TPL, и API для синхронного использования, что ещё удобнее - и он должен быть не менее быстрым чем синхронная работа с файлами, потому что это встроенная БД.
    Но если вы по каким-то причинам будете работать с асинхронным API на функциях обратного вызова, то тут тоже есть способ упростить код: транслировать вызовы такого API для использования его со средствами TPL. Для этого используйте объект типа TaskCompletionSource (в вашем случае - обобщенный, специалиированный вашим типом результата: TaskCompletionSource<int>
    У этого объекта есть свойство Task, возвращающее задачу, состоянием котрой можно управлять с помощью методов этого объекта - SetResult и других, вызывая эти методы в функциях обратного вызова (AKA callback). Как это делать - см. пример по ссылке.
    А с Task, каким бы способом вы его не получили, вам будет работать значительно удобнее: если пометить метод, в котором вам надо работать с БД как async (в современном C# так можно пометить даже Program.Main), то в этом методе можно будет использовать для получения значения операцию await
    TaskCompletionSource<int> tcs1=new TaskCompletionSource();
    //... операции по по настройке tcs1 и запуску первого чтения из БД
    int numberFromBase1 = await tcs1.Task.ConfigureAwait(false);
    TaskCompletionSource<int> tcs2=new TaskCompletionSource();
    //... операции по по настройке tcs2 и запуску второго чтения из БД
    int numberFromBase2 = await tcs2.Task.ConfigureAwait(false);
    int summ =  numberFromBase1 + numberFromBase2;
    return summ;

    Вызов ConfigureAwait(false) здесь нужен для избежания блокировок в некоторых контекстах синхронизации (приложения Windows Forms, WPF и др.). Если же у вас программа выполняется вне специфического контекста синхронизации - консольное приложение, приложение ASP.NET Core и др., - то этот вызов не обязателен.
    Компилятор, увидев операцию await, преобразует метод нужным образом, так, чтобы он выполнялся асинхронно, передавая управление другим задачам во время ожидания (т.е. до выполнения функции обратного вызова) и возобнавлял выполнение по его завершении -и вам думать об этом и писать нужный для этого код будет не нужно.
    Такой метод вернет Task (возможно - ещё до завершения всех операций) и с его результатом можно что-то сделать: либо получить его опять чере await асинхронно, либо дождаться завершения асинхронных операций с получением результата через вызов метода Task<int&gt.GetAwaiter().GetResult() (есть другие варианты, но этот IMHO лучше всего в плане обработки исключений).
    Ответ написан
    Комментировать
  • Как именно должжна работать функция SetCursor?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Ну, не так может быть то, что курсор назначаен на уровне класса окна (задается при регистрации класса приложением, но можно изменить и после) - тогда при движении мыши система заменяет ваш курсор на зарегистрированный. Подробности читать тут.
    Ответ написан
    Комментировать
  • Как удалить строки, полученные подзапросом с фильтрацией и сортировкой?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Как известно, в однотабличном запросе - ровно одна таблица в FROM, без JOIN, подзапросы (в скобках) не в счет - удалить строки, которые выбирает оператор SELECT не просто, а очень просто: достаточно заменить SELECT (со списком полей) на DELETE.
    Ваш запрос, начиная со второй строчки, можно преобразовать к такому виду: в FROM указать имя самой таблицы, а отбор строк сделать через подзапрос в разделе WHERE. Если в таблице есть первичный ключ из одного поля, то это делается проще всего через подзапрос для ANY, выбирающий нужный первичный ключ , а в общем случае это делается через подзапрос для EXISTS. Существующее условие WHERE надо перенести в подзапрос. А потом - просто заменить первую строчку на DELETE.
    Ответ написан
  • Почему сетевые клиенты (PXE) загружаются со старого сервера после изменения настройки в микротике?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Сервер, выдающий загружаемые образы для PXE, часто сам отвечает по DHCP на соответсвующие запросы, которые рассылаются через широковещание.
    Так что, смотрите настройки старого сервера.
    Ответ написан
    1 комментарий
  • Получить вывод команды командной оболочки в переменную makefile?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    В командной строке:
    for /F %i in ('powershell.exe $PSVersionTable.PSVersion.Major') do set PSVER=%i

    Если вставляете в командный файл - замените %i на %%i
    Ответ написан
  • Как ограничить вывод?

    @mvv-rus
    Настоящий админ AD и ненастоящий программист
    Powershell работает с объектами и фильтровать надо объекты. По факту вы хотите получить элементы свойства Access и отфильтровать их - вот и пишите этот фильтр явно, а потом преобразовывайте выдачу в нужный вам формат . Для одного субъекта это делается примерно так(выдачаформатируется так же, как и у вас):
    (Get-Acl \\addr\addr).Access | Where {$_.IdentityReference -ne 'Домен\Группа'} | ForEach ([String]$_.IdentityReference, String]$_.AccessControlType, [String]$_.FileSystemRights) -join ' '}

    Чтобы отфильтровать несколько групп либо добавьте в команду Where дополнительные аналогичные условия, объединив их по && , либо добавьте команды Where для каждой такой группы
    Теоретически, можно отфильтрофать и результат команды Format-List, которой вы пользуетесь, но это сложнее: она возвращает не строки, а весьма нетривиальные объекты, которые потом формируют выдачу
    Ответ написан
    2 комментария