Nano Hash - криптовалюты, майнинг, программирование

Переменная PATH отличается, когда cmd запускается через контекстное меню

Я только что потратил последний час, пытаясь выяснить, почему, черт возьми, моя переменная PATH не обновлялась для моего cmd.exe. Теперь я понял, что он вроде как обновлялся, но только при определенных условиях...
Обновлял через Win+Break -> Change Settings -> Advanced -> Environment Variables...

Теперь, когда я открываю новую командную строку через Win+R -> cmd -> Enter, переменная PATH показывает то, что я для нее установил.
Но когда я открываю новую командную строку через Shift+Rightclick into folder -> Open command window here, переменная PATH показывает устаревшее содержимое.

введите здесь описание изображения

Мой вопрос: почему это происходит, что я могу с этим поделать?


  • Вы обновили реестр с помощью 1-го шага. Эти изменения не вступают в силу до тех пор, пока процесс не будет запущен и не унаследует среду своего родительского процесса. Вам придется перезапустить Explorer.exe, самый простой способ сделать это — выйти из системы и войти снова. 26.04.2015
  • @HansPassant Вау ... это решило проблему. Спасибо, опубликуйте это как ответ, чтобы я мог принять его. 26.04.2015
  • @HandPassant, окна верхнего уровня получают сообщение WM_SETTINGCHANGE, когда панель управления обновляет настройки среды, для чего Explorer вызывает shell32!RegenerateUserEnvironment для перезагрузки своей среды. Так как же проводник (родительский в обоих случаях) использует новую среду в одном случае, но не использует в другом? Возможно, позже я посмотрю на это в отладчике, чтобы увидеть, что происходит. Перезапуск сеанса на первый взгляд решает проблему, но не объясняет поведение. 26.04.2015
  • @eryksun: у меня такое ощущение, что открытое командное окно здесь — это сторонний плагин. (Я не вижу его на своей машине.) Так что, вероятно, он просто не знает, где найти последнюю версию блока среды. 27.04.2015
  • @HarryJohnston, это в Windows 7. Он не должен открывать командную строку с повышенными привилегиями, но, вероятно, Forivin просто отключил UAC. 27.04.2015
  • Да, UAC полностью отключен, и я на Windows 8.1. Функция Shift+Rightclick реализована начиная с Windows 7. 28.04.2015
  • @HansPassant Я только что заметил, что этот вопрос был решен в комментариях. Вероятно, было бы неплохо сделать этот комментарий реальным ответом. 11.10.2015
  • Конечно, не стесняйтесь опубликовать ответ самостоятельно и принять его. 11.10.2015

Ответы:


1

Как указал Ханс Пассант, проблема заключалась в том, что запуск cmd через контекстное меню проводника порождает cmd как дочерний процесс для проводника, заставляя его наследовать переменные среды из explorer.exe вместо того, чтобы приобретать их самостоятельно. А поскольку процесс обычно загружает переменные среды только один раз в начале и не прослушивает изменения, проводник унаследовал устаревшие переменные от экземпляра cmd.

Таким образом, решением будет просто перезапустить explorer.exe.

11.10.2015
  • Я совершенно уверен, что Explorer также является родителем для программ, запускаемых из меню «Пуск», поэтому я думаю, что причина немного сложнее: Explorer должен видеть изменения переменной среды, но по какой-то причине код, который реализует контекст меню пренебрегает их уважением. Впрочем, это не имеет большого значения, так как разрешение одинаково в любом случае. 12.10.2015
  • Они запускаются как дочерние элементы для разных процессов проводника. i.snag.gy/wYivz.jpg Но вы, вероятно, правы, и это немного сложнее, чем я думал. Может быть, это просто происходит со всеми процессами, которые являются дочерними процессами services.exe или около того... 12.10.2015
  • Вау, это действительно странно. Я имею в виду, что, учитывая, что это отдельный экземпляр explorer.exe, работающий в контексте службы, вполне логично, что переменные среды не обновлены. Я просто озадачен тем, почему в контексте службы работает отдельный экземпляр! Между прочим, это может иметь множество других побочных эффектов для программ, запускаемых из этого командного окна, некоторые из которых, вероятно, хуже, чем проблема с переменной среды. Поэтому я бы рекомендовал избегать этого конкретного пункта меню. :-) 12.10.2015
  • Отдельный экземпляр, работающий в контексте службы, возникает, когда у вас есть Запустить окна папки в отдельном процессе. Опция установлена ​​​​в проводнике или выберите «Файл» › «Открыть новое окно» › «Открыть новое окно в новом процессе». Порожденный процесс представляет собой внепроцессный COM-сервер, который, по-видимому, не знает (или нечувствителен к) сообщению WM_SETTINGCHANGE. 11.10.2018
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..