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 / unix / Perguntas / 513926
Accepted
Evan Benn
Evan Benn
Asked: 2019-04-23 16:57:51 +0800 CST2019-04-23 16:57:51 +0800 CST 2019-04-23 16:57:51 +0800 CST

O que controla o buffer de stdout stderr?

  • 772

Que parte do sistema configura o buffer dos três fluxos padrão quando um programa é iniciado?

Isso é parte do linux, ou glibc, ou talvez bash? O POSIX define o comportamento ou faz parte de C?

Posix tem algumas respostas:

https://pubs.opengroup.org/onlinepubs/9699919799/functions/V2_chap02.html#tag_15_05

Na inicialização do programa, três fluxos são predefinidos e não precisam ser abertos explicitamente: entrada padrão (para leitura de entrada convencional), saída padrão (para gravação de saída convencional) e erro padrão (para gravação de saída de diagnóstico). Quando aberto, o fluxo de erro padrão não é totalmente armazenado em buffer; os fluxos de entrada padrão e de saída padrão são totalmente armazenados em buffer se e somente se o fluxo puder ser determinado para não se referir a um dispositivo interativo.

Portanto, se o sistema pode determinar que os fluxos NÃO são interativos, eles podem ser totalmente armazenados em buffer (exceto stderr), mas na prática, qual parte do sistema isso determina?

linux stdout
  • 1 1 respostas
  • 2684 Views

1 respostas

  • Voted
  1. Best Answer
    JdeBP
    2019-04-24T02:45:00+08:002019-04-24T02:45:00+08:00

    Sua linguagem de programação

    Esse comportamento é um artefato da biblioteca de tempo de execução C e um requisito da linguagem de programação C. Historicamente, outras linguagens de programação foram construídas em cima da biblioteca de tempo de execução C e obtêm esse comportamento dela. Isso é verdade para programas C++, por exemplo. O capítulo e o verso dos padrões de linguagem C e C++ são citados com bastante frequência no Stack Overflow (qv).

    Mais notavelmente, os programas escritos em Python têm o mesmo comportamento e são questionados com bastante frequência, às vezes com a culpa pelo comportamento do tempo de execução da linguagem de programação ser mal colocado.

    As ferramentas para alterar esse comportamento de programas que usam a semântica da linguagem padrão (sem modificar e recompilar os programas) vêm em duas formas: ferramentas dependentes da linguagem (e às vezes específicas da biblioteca de tempo de execução) que se inserem no tempo de execução e alteram o buffer, e ferramentas que transformam E/S padrão em arquivos que as bibliotecas de tempo de execução decidem ser dispositivos interativos. As ferramentas da última classe são independentes de linguagem e incluem Bernstein ptybandage.

    Leitura adicional

    • https://unix.stackexchange.com/a/407472/5132
    • https://unix.stackexchange.com/a/249801/5132
    • http://git.musl-libc.org/cgit/musl/tree/src/stdio/__stdout_write.c#n8

    Apenas algumas instâncias da questão do buffer:

    • Escreva Python stdout no arquivo imediatamente
    • Obtendo logs de serviço systemd mais rapidamente do meu serviço
    • O serviço Systemd Python não está enviando toda a saída para o syslog
    • A saída de um script python em execução como unidade está fora de ordem enquanto os shells parecem não afetados
    • O multilog do Daemontools perde as informações de tempo da linha de log. Como corrigi-lo?
    • stderr é liberado antes do stdout, ao usar o registrador de arquivos
    • A saída de um script python em execução como unidade está fora de ordem enquanto os shells parecem não afetados
    • systemd: processo com fork() só mostra logs após a saída do filho
    • 4

relate perguntas

  • Existe uma maneira de fazer ls mostrar arquivos ocultos apenas para determinados diretórios?

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

  • Necessidade de algumas chamadas de sistema

  • astyle não altera a formatação do arquivo de origem

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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