Задать вопрос
  • Есть ли альтернатива Microsoft RD Client на Mac?

    Можно взять отдельную машину, поставить на нее guacamole и сидеть из браузера
    Ответ написан
    Комментировать
  • Как найти коммит после отката?

    egor_nullptr
    @egor_nullptr
    Если вы успели закоммитить свои изменения, то найдите этот коммит при помощи git reflog и переключитесь на него при помощи git checkout.
    Ответ написан
    2 комментария
  • Разница между @~ и @^?

    Lynn
    @Lynn
    nginx, js, css
    Разница описана в документации.

    В частности @^ и @~ действительно совершенно случайно выбирают одно и тоже, но у них разный смысл.

    @ в данном контексте синоним HEAD.
    ^ (=== ^1) — выбрать первого родителя коммита. У большинства коммитов никакого другого и нет, так что числа отличные от 1 имею смысл только для merge-коммитов.
    ~ (=== ~1) — выбрать родителя (если их несколько, то выбирается первый).

    Но, например, @^3 выбрать третьего родителя у коммита. В 99.99% случаем это будет ошибка, потому что в живой природе больше двух родителей практически не бывает.
    А вот @~3 означает выбрать «пра-дедушку» коммита и это эквивалентно записи @^1^1^1 (или @^^^).
    Ответ написан
    1 комментарий
  • Почему git не игнориует указанные файлы?

    @dasdasdsadas Автор вопроса
    Проблема была связана с неправильной кодировкой файла .gitignore, а именно стояла UTF-16 LE из-за чего неправильно интерпретировались правила. При смене на UTF-8 заработало
    Ответ написан
    Комментировать
  • Как правильно клонировать приватный репозиторий github?

    Там же написано

    Support for password authentication was removed on August 13, 2021. Please use a personal access token instead.
    Ответ написан
    Комментировать
  • Ubuntu изменил название сетевого интерфейса как это возможно?

    Rsa97
    @Rsa97
    Для правильного вопроса надо знать половину ответа
    Изменилась первичная схема именования устройства. Приоритеты:
    1. eno1 - сетевое устройство 1 на материнской плате. Используется, если из BIOS возможно получить информацию об интегрированных устройствах.
    2. ens4 - сетевое устройство в PCI express hot-plug слоте 4. Используется, если из BIOS возможно получить информацию об устройствах на шине PCIe.
    3. enp4s0 - сетевое устройство 0 в PCI-слоте 4. Используется, если возможно определить слот.
    4. eth0 - сетевое устройство 0. Используется, если не подошли предыдущие схемы. Порядок устройств определяется порядком загрузки драйверов.
    5. enx78e7d1ea46da - сетевое устройство с MAC-адресом 78:e7:d1:ea:46:da. Такой режим можно включить вручную.
    Ответ написан
    6 комментариев
  • У кого есть позитивный переход с Windows на Astra Linux в гос/бюджетной сфере?

    @Drno
    Хотите пасс секс? Переходите
    Хотите ночевать на работе? Переходите
    Хотите лишиться КПИ? Переходите
    Хотите кучу гемора, еще и на энтузиазме?)) переходите

    Самый простой дистр для новичка - это Линукс Минт. И она бесплатна. Или чистая убунту. И там будет скорее всего всё работать
    Рабочий стол как в астре ставится в пару команд. А гемора с репами и софтом не будет...
    Ответ написан
    9 комментариев
  • У кого есть позитивный переход с Windows на Astra Linux в гос/бюджетной сфере?

    Цель конечно благая.
    Однако насчет успешного перехода - это всегда боль и слезы. Такие вещи проходят только при жесткой поддержке руководства (партия сказала 'надо!'), либо комп используется только например для экзамена в ГИБДД, как написал выше уважаемый коллега.
    Из того что точно всплывет:
    • Офисный пакет - полной совместимости между MS Office и Libre Office нет, а это значит негатив пользователей 'ты придумал поставить этот линекс, ты и исправляй документ'
    • Если в организации Exchange - то аутлука под линукс нет, все остальное - костыли. Они вроде бы как то работают, но 'полной совместимости нет'
    • 1С - даже если заработает в Линуксе (например веб-клиент), то вероятно поплывут формы, которые выгружаются в формате Word или Excel. А это значит что нужно чтобы те кто поддерживают 1С вам эти формы допилили, что может уже привести к прямым затратам.


    Я бы посоветовал подождать - есть подозрение что импортозамещение скоро пойдет галопом, и тогда у вас будет активная поддержка руководства.
    Ответ написан
    3 комментария
  • Почему GitHub не предоставляет доставляет доступ к оболочке?

    @Akela_wolf
    Extreme Programmer
    А что вы хотите от шелла в гитхабе? Выполнять команды на его серверах? Зачем?
    SSH у гитхаба имеет простое назначение - аутентификация и туннель для доступа к репозиториям. Зачем там шелл?
    Ответ написан
    Комментировать
  • Как оживить docker на windows 10?

    Tomio
    @Tomio
    backend developer (python, php)
    А WSL2 вы устанавливали?
    Ответ написан
    1 комментарий
  • Как убрать текстовые подсказки в vscode?

    Alexandre888
    @Alexandre888
    Javascript-разработчик
    F1 => settings.json =>
    {
        ...
        "editor.suggest.showWords": false
    }
    Ответ написан
    Комментировать
  • Как перенести данные профиля одного пользователя в другой новый созданный?

    hint000
    @hint000
    у админа три руки
    Уже были ответы на ваш вопрос:
    https://qna.habr.com/q/1044384
    https://qna.habr.com/q/374061
    Там и ссылка на утилиту, и лайфхак для лёгкого копирования вручную.
    Ответ написан
    Комментировать
  • Стоит ли использовать микрокомпьютер для удаленной работы?

    Griboks
    @Griboks
    думаю, найти монитор большого труда не составит

    На этом месте ваш план заершился неудачей. Вы нигде не найдёте одиноко стоящий на столе монитор.
    Ответ написан
    Комментировать
  • Есть ли смысл покупать Fork?

    @res2001
    Developer, ex-admin
    Во многих IDE есть встроенный клиент git. Стандартные операции типа комита и пуша делать там вполне можно.
    Для чего-то большего использую стандартную консольную версию.
    Ответ написан
    Комментировать
  • Нехватка электропитания USB-Порта, что делать?

    saboteur_kiev
    @saboteur_kiev Куратор тега Windows
    software engineer
    Все порты на материнке в основном питаются с одной usb шины, поэтому выход один - купить внешний USB хаб с независимым питанием от розетки и проверить.
    Ответ написан
    Комментировать
  • Нехватка электропитания USB-Порта, что делать?

    Stalker_RED
    @Stalker_RED
    Док-станция или юсб-хаб с внешним питанием, не?

    И вы бы хоть описали что подключает, потому что три флешки это одна история, а если три внешних hdd, то другая.

    UPD: возможно в каком-то из ваших устройств поврежден кабель, попробуйте определить какое именно устройство вызывает табличку. Или по отдельности они все хорошо работают?
    Ответ написан
    8 комментариев
  • Как корректно произвести множественное наследование в Python 3?

    ScriptKiddo
    @ScriptKiddo
    https://stackoverflow.com/a/58337004

    class A:
        def __init__(self):
            super().__init__()
            self.aa = 2
    
    
    class B:
        def __init__(self):
            super().__init__()
            self.ab = 3
    
    
    class C(A, B):
        pass
    
    
    c = C()
    print(c.aa, c.ab)
    Ответ написан
    1 комментарий
  • На собеседовании сказали, что не все функции - замыкания. Так ли это?

    greenkey
    @greenkey
    программист
    Не стоит ругаться и обвинять друг друга в некомпетентности ;-) не знать чего-либо совершенно нормально, даже если ты лет двадцать без устали кодишь. Настоящего профессионала отличает не то, что он знает вообще все, а то, что он прекрасно осознает, что много чего не знает, и его это нисколько не смущает - мы учимся постоянно. Для меня, например, некоторые моменты связанные с closures оказались новыми, и я решил, что надо поглубже погрузиться в данный вопрос.
    А он не так прост, как может показаться на первый взгляд, и содержит в себе целый ряд нюансов, поэтому чрезвычайно важно 1) оперировать одинаково понимаемыми терминами, 2) пойти в документацию, а именно в ecmascript, и, как правильно заметил dollar , проверить, как это было реализовано уже в реальной реализации javascript, в движке, например V8.
    Вопрос, хоть и теоретический, но очень важный, потому что проливает свет на понимание работы современных языков "изнутри", что безусловно важно хорошему программисту.
    Предлагаю всем, кого вопрос также заинтересовал, немного погрузиться в теорию, для начала вот это:
    https://262.ecma-international.org/12.0/#sec-abstr...
    более развернуто в статье, хоть и старой, но принцип closure не поменялся
    dmitrysoshnikov.com/ecmascript/chapter-6-closures
    Оно же на русском:
    dmitrysoshnikov.com/ecmascript/ru-chapter-6-closures
    Ответ написан
    Комментировать
  • На собеседовании сказали, что не все функции - замыкания. Так ли это?

    @Arlekcangp
    Разработчик, Лид, Архитектор ПО
    Похоже вас поймали на том что в js кто-то решил переопределить термин "замыкание"... Т к javascript далеко не первый язык, в котором есть нечто, претендующее называться термином "замыкание", то следует в первую очередь рассмотреть общее определение. Возьмём его из википедии:

    Замыкание (англ. closure) в программировании — функция первого класса, в теле которой присутствуют ссылки на переменные, объявленные вне тела этой функции в окружающем коде и не являющиеся её параметрами. Говоря другим языком, замыкание — функция, которая ссылается на свободные переменные в своей области видимости.
    Замыкание, так же как и экземпляр объекта, есть способ представления функциональности и данных, связанных и упакованных вместе.
    Замыкание — это особый вид функции. Она определена в теле другой функции и создаётся каждый раз во время её выполнения. Синтаксически это выглядит как функция, находящаяся целиком в теле другой функции. При этом вложенная внутренняя функция содержит ссылки на локальные переменные внешней функции. Каждый раз при выполнении внешней функции происходит создание нового экземпляра внутренней функции, с новыми ссылками на переменные внешней функции.
    В случае замыкания ссылки на переменные внешней функции действительны внутри вложенной функции до тех пор, пока работает вложенная функция, даже если внешняя функция закончила работу, и переменные вышли из области видимости.[1]
    Замыкание связывает код функции с её лексическим окружением (местом, в котором она определена в коде). Лексические переменные замыкания отличаются от глобальных переменных тем, что они не занимают глобальное пространство имён. От переменных в объектах они отличаются тем, что привязаны к функциям, а не объектам.


    Как видим из этого длинного определения (а не только его первого предложения) интервьюер оказался формально прав (что является неожиданностью и для меня самого. Кто знает, возможно это веяние нового или всё же творчество чрезмерного ЧСВ js-кодерков, но не будем предвзятыми) Посмотрим дальше...Переходим в английскую версию той же страницы в википедии:

    In programming languages, a closure, also lexical closure or function closure, is a technique for implementing lexically scoped name binding in a language with first-class functions. Operationally, a closure is a record storing a function[a] together with an environment.[1] The environment is a mapping associating each free variable of the function (variables that are used locally, but defined in an enclosing scope) with the value or reference to which the name was bound when the closure was created.[b] Unlike a plain function, a closure allows the function to access those captured variables through the closure's copies of their values or references, even when the function is invoked outside their scope.


    О! А тут нет никаких "функций, вложенных в функцию" и нет никаких "создающихся каждый раз" Хм... Интересно. Ну за то есть абзац о том как появились замыкания:

    The concept of closures was developed in the 1960s for the mechanical evaluation of expressions in the λ-calculus and was first fully implemented in 1970 as a language feature in the PAL programming language to support lexically scoped first-class functions.[2]

    Peter J. Landin defined the term closure in 1964 as having an environment part and a control part as used by his SECD machine for evaluating expressions.[3] Joel Moses credits Landin with introducing the term closure to refer to a lambda expression whose open bindings (free variables) have been closed by (or bound in) the lexical environment, resulting in a closed expression, or closure.[4][5] This usage was subsequently adopted by Sussman and Steele when they defined Scheme in 1975,[6] a lexically scoped variant of Lisp, and became widespread.


    Ага. Оказывается первоначально они появились в такой не конвенциональной, с сегодняшней точки зрения VM, как SECD... И их создатель прямо говорит, что это код плюс данные. Далее термин применяют к лямбда-выражениям. Ничего не говорится, должны ли эти выражения возвращаться функцией, или достаточно того, что бы они захватывали переменные из своего лексического (или динамического, как в common lisp) окружения. Далее нам сообщают, что некие мистеры, Сасман и Стил, спустя каких то 11 лет добавили это в свой язык Scheme... Ну что же. Посмотрим замыкания в Scheme... А именно откроем книгу Сасмана и соавторов "Структура и интерпретация компьютерных программ" или "SICP" Первый раз (исключая содержание) слово "замыкание" встречается в главе 2 "Поcтроение абстракций c помощью данных"


    Важная идея в работе с составными данными — понятие замыкания (closure): клей для
    сочетания объектов данных должен позволять нам склеивать не только элементарные
    объекты данных, но и составные.


    Но, как выяснилось, это не те замыкания... Это замыкание в том смысле, что структуру одного типа (в данном случае пары) могут ссылаться на самих себя. И это то как термин "замыкание" понимают математики. Далее в SICP никаких других определений замыканий нет (несмотря на то, что само их использование конечно же есть) Ну ничего не остаётся как посмотреть что же сегодня называют замыканиями в языке Scheme... Гугл по этому запросу выдал первой ссылкой: https://www.cs.utexas.edu/ftp/garbage/cs345/schint....
    Цитирую:

    Procedures are Closures
    Scheme procedure's aren't really just pieces of code you can execute; they're closures.

    A closure is a procedure that records what environment it was created in. When you call it, that environment is restored before the actual code is executed. This ensures that when a procedure executes, it sees the exact same variable bindings that were visible when it was created--it doesn't just remember variable names in its code, it remembers what storage each name referred to when it was created.

    Since variable bindings are allocated on the heap, not on a stack, this allows procedures to remember binding environments even after the expressions that created those environments have been evaluated. For example, a closure created by a lambda inside a let will remember the let's variable bindings even after we've exited the let. As long as we have a pointer to the procedure (closure), the bindings it refers to are guaranteed to exist. (The garbage collector will not reclaim the procedure's storage, or the storage for the let bindings.)

    Here's an example that may clarify this, and show one way of taking advantage of it.

    Suppose we type the following expression at the Scheme prompt, to be interpreted in a top-level environment:

    Scheme> (let ((count 0))
               (lambda ()
                  (set! count (+ count 1))
                  count)))

    ##

    Evaluating this let expression first creates a binding environment with a binding for count. The initial value of this binding is 0. In this environment, the lambda expression creates a closure. When executed, this procedure will increment the count, and then return its value. (Note that the procedure is not executed yet, however--it's just created.) This procedure, returned by the lambda expression, is also returned as the value of the let expression, because a let returns the value of its last body expression. The read-eval-print loop therefore prints a representation of the (anonymous) procedure.


    Что имеем ? В Scheme - вообще любая функция - это замыкание! Т к она всегда захватывает контекст, даже если там пусто!. Что видим в коде ? Ну с точки зрения Scheme тут конечно вложенная функция, т к let - это на самом деле lambda, но так происходит потому, что в Scheme нет переменных в понимании js. В js же можно считать, что глобальный контекст - результат действия нечто, что эквивалентно let. Захватывает ли любая функция в js этот контекст ? Не знаю. Но точно знаю, что в вашем примере это определенно так - х часть контекста, который захватывается функцией. Кто хочет поспорить - идите спорьте с создателями Scheme (скажите, когда попкорн покупать, я посмотрю как вас пороть будут. Набежало тут вайтишников =)) Кто то может сказать "а вот у нас в js замыкания определяются не так" На что я отвечу: знаете, товарищи, а идите ка вы лесом! Если есть однажды созданный и определенный термин, нужны весьма веские причины что бы менять его определение. Желания левой ноги очередного вайтишника тут не достаточно.
    Ответ написан
    30 комментариев