AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1881251
Accepted
shynur
shynur
Asked: 2025-02-19 16:24:35 +0800 CST2025-02-19 16:24:35 +0800 CST 2025-02-19 16:24:35 +0800 CST

Por que o terminal congela toda vez que executo `$EDITOR >(cmd)`?

  • 772

>(cmd)é uma sintaxe Bash. Por exemplo,

$ echo 42 > >(cat)
42

Isso funciona bem.

Então, espero usar esse método para passar o arquivo recém-editado e salvo como entrada para outro comando (estou usando apenas catcomo exemplo):

$ EDITOR=nano  # or emacs, vi, ...
$ $EDITOR >(cat)

Então ele simplesmente congelou. Por quê?

bash
  • 1 1 respostas
  • 442 Views

1 respostas

  • Voted
  1. Best Answer
    grawity
    2025-02-19T16:49:30+08:002025-02-19T16:49:30+08:00

    O editor está tentando ler o texto atual do arquivo que você especificou, como editores de texto geralmente fazem. Como nada foi escrito no pipe (ainda que o pipe ainda esteja aberto para escrita), o editor ficará preso para sempre na read()chamada, esperando que os dados cheguem.

    Para fazer a ideia funcionar, você precisará criar um pipe nomeadomkfifo usando . Inicie o editor e (simultaneamente, em segundo plano) faça cat/echo do seu texto para o pipe – mesmo que não haja texto, ainda é importante abrir e fechar o pipe para escrita pelo menos uma vez – antes de dar o pipe para o programa "leitor". Isso pode ser difícil de conseguir no bash, pois o leitor precisa já estar em execução quando o nano for solicitado a escrever o novo texto, mas só deve ser executado depois que o nano já tiver lido o texto original.

    É uma ideia melhor usar mktempum arquivo temporário regular.


    Usar >(…)fornece ao seu editor um descritor de arquivo representando a extremidade 'write' do pipe (enquanto cat está segurando a extremidade 'read') e um /dev/fd/###caminho de estilo para esse descritor de arquivo.

    • Argumentos da linha de comando: [ nano, /dev/fd/63]
    • Descritores de arquivo: { 0←tty, 1→tty, 2→tty, 63→pipe}

    Mas o editor não reconhece especificamente /dev/fdcaminhos como "isso representa um FD que eu já tenho, então vamos usar isso" – em vez disso, o editor o trata como qualquer outro caminho, chamando open()e obtendo um novo descritor de arquivo. (Ele continua sem saber que tem o FD #63.)

    A maneira como /dev/fdfunciona no Linux (não apenas com pipes, mas com tentativas de reabrir "caminhos do descritor de arquivo" em geral) é que isso é tratado como uma tentativa completamente nova de abrir aquele arquivo ou objeto, em vez de duplicar o descritor de arquivo 1:1.

    • O editor faz: open("/dev/fd/63", O_RDONLY)⇒3
    • FDs agora: { 0←tty, 1→tty, 2→tty, 3←pipe, 63→pipe}

    Portanto, se o editor abrir esse caminho para leitura , ele de fato obterá um descritor de arquivo para a extremidade 'leitura' do pipe, não para a extremidade 'gravação' – e, portanto, as read()chamadas subsequentes não falharão imediatamente com um erro "tentando ler de um FD somente gravação", como teria acontecido com o FD original, mas, em vez disso, bloquearão a espera por dados.

    Nesse sentido, o /dev/fdcaminho do Linux para um pipe anônimo se comporta exatamente como um caminho regular para um pipe nomeado se comportaria. Se você fosse criar um pipe usando mkfifo ~/foo, o editor também o abriria para leitura e ficaria preso tentando ler a partir dele – até que você ecoasse algo para o pipe.

    Mas além de tudo isso: pipes só relatam "fim do arquivo" quando o fim da gravação está completamente fechado . Então, como o editor ainda mantém, sem saber, o descritor de arquivo original #63 para o fim da 'gravação', isso significa que sempre há um escritor ativo – o próprio editor – e mesmo que ele pudesse receber alguns dados pelo pipe (por exemplo, escritos via 'echo' manual através de /proc/PID/fd), ele ainda continuaria esperando para sempre pela indicação de "fim do arquivo". Na verdade, o editor está em um deadlock consigo mesmo.

    O último problema não acontece com pipes nomeados, pois não há um descritor de arquivo aberto preexistente para o pipe – o hipotético echo yay > ~/yayé o único escritor, então, assim que ele sai, o editor alcança "EOF" e mostra o texto. Então, se você deseja experimentar, eu sugiro fortemente experimentar pipes nomeados para obter um ambiente mais controlado do que os métodos envolvendo /dev/fd.

    • 6

relate perguntas

  • substituindo zsh por bash no usuário não root

  • Tendo problemas para definir variáveis ​​de ambiente no Terminal no macOS High Sierra

  • Existe um equivalente a cd - para cp ou mv?

  • Notificar-enviar notificações aparecendo na janela

  • como abrir um arquivo de escritório do WSL

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Vickel O Firefox não permite mais colar no WhatsApp web? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve