AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 519789
Accepted
agc
agc
Asked: 2019-05-20 03:28:04 +0800 CST2019-05-20 03:28:04 +0800 CST 2019-05-20 03:28:04 +0800 CST

Shell内置`printf`行限制?

  • 772

/usr/bin/printfutil 参数列表长度限制为 shell 的最大命令行长度(即, getconf ARG_MAX在我的系统上为2097152);例子:

# try using a list that's way too long
/usr/bin/printf '%s\n' $(seq $(( $(getconf ARG_MAX) * 2 ))) | tail -1

输出:

bash: /usr/bin/printf: Argument list too long

今天我被告知shell builtin printf没有这个限制。测试:

printf '%s\n' $(seq $(( $(getconf ARG_MAX) * 2 ))) | tail -1

输出:

4194304

问题:

  1. 略读man bash dash一下似乎并没有说明builtin printf的这种优势。它记录在哪里?

  2. builtin printf s ( eg )是否bash有一个以字符为单位的参数列表最大长度,如果有,该长度是多少?

bash shell
  • 3 3 个回答
  • 1420 Views

3 个回答

  • Voted
  1. Kusalananda
    2019-05-20T03:36:58+08:002019-05-20T03:36:58+08:00

    提倡使用任何特定实用程序并不是手册的真正职责。它应该主要描述可用的内置实用程序。

    使用内置实用程序相对于外部实用程序的优势主要在于速度和扩展功能的可用性(例如printf,bash可以使用 直接写入变量-v varname,这是外部printf无法做到的)。

    与执行内置实用程序相比,执行外部实用程序很慢,特别是如果经常在循环中执行,而且,正如您所注意到的,它们还允许更长的参数列表(这不是只有内置printf允许的,但所有内置实用程序)。

    内置printf实用程序的参数列表的长度受进程本身bash的资源限制的限制。bash在某些系统上,这甚至可能意味着您可以使用大部分可用 RAM 来构建其命令行参数列表。

    您可以从中找到这些不同信息的文档是

    • bash源代码,您将在其中看到参数列表printf是动态分配的链表,并且它不用于execve()运行printf(这是在运行外部实用程序时限制参数列表长度的原因)。

    一个没有printf内置实用程序的shell示例是OpenBSD 的 shell。该实用程序也可以在使用时禁用。kshbashenable -n printf

    • 13
  2. Best Answer
    mosvy
    2019-05-20T12:18:22+08:002019-05-20T12:18:22+08:00

    /usr/bin/printf util 参数列表长度限制为 shell 的最大命令行长度(即 getconf ARG_MAX,在我的系统上为 2097152);例子:

    这不是shell的限制,而是操作系统(Linux 内核)的限制,特别是其execve(2)系统调用的限制,并且是由命令行参数和环境变量传递给已启动程序的过时方式引起的。

    (请注意,该限制还包括环境变量!)。

    浏览一下 man bash dash 似乎并没有说明内置 printf 的这种优势。它记录在哪里?内置 printfs 是否有参数列表长度(例如 bash),如果有,它是什么?

    由于 shell 内置程序没有通过execve(2),因此它们不必有任何限制。现代 shell 通常不使用固定大小的缓冲区等,因此限制通常是由可用内存量和虚拟地址空间的布局强加的——即,对于所有意图和目的来说,它都是无限的。

    • 2
  3. schily
    2019-05-21T06:07:54+08:002019-05-21T06:07:54+08:00

    POSIX 标准要求在没有行限制的情况下实现 shell。

    所以这是贝壳没有记录的自然现象。

    顺便说一句:由于这个事实,shell 脚本可能不是文本文件,因为文本文件是行数不超过 LINE_MAX 的文件;-)

    • 0

相关问题

  • 从文本文件传递变量的奇怪问题

  • 虽然行读取保持转义空间?

  • 如何将带有〜的路径保存到变量中?

  • `tee` 和 `bash` 进程替换顺序

  • 运行一个非常慢的脚本直到它成功

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

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

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve