- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是否正确理解该程序导致UB的标准:
#include <stdio.h>
int main(void)
{
char a = 'A';
printf("%c\n", a);
return 0;
}
当它在 sizeof(int)==1 && CHAR_MIN==0
的系统上执行时?
因为如果 a
是无符号的并且具有与 int
相同的大小 (1),它将被提升为 unsigned int
[ 1] (2),而不是 int
,因为 int
不能表示 char
的所有值。格式说明符 "%c"
需要一个 int
[2],并且在 printf()
中使用错误的符号会导致 UB [3]。
C99 ISO/IEC 9899 的相关引用
[1] 根据 C99 6.3.1.1:2 升级为 int
:
If an
int
can represent all values of the original type, the value isconverted to anint
; otherwise, it is converted to anunsigned int
.These are called the integer promotions. All other types areunchanged by the integer promotions.
[2] 格式说明符 "%c"
需要一个 int
参数,C99 7.19.6.1:8 c
:
If no
l
length modifier is present, theint
argument is converted toanunsigned char
, and the resulting character is written.
[3] 在 fprintf()
(3) 中使用错误的类型,包括错误的符号,会导致根据 C99 7.19.6.1:9 的 UB:
... If any argument is not the correct type for the correspondingconversion specification, the behavior is undefined.
对于 va_arg
宏,给出了具有不同符号的相同类型的异常(exception)情况,但对于 printf()
则没有,并且不要求 printf()
使用 va_arg
(4)。
脚注:(用 (n) 标记)
这意味着 INT_MAX==SCHAR_MAX
,因为 char
没有填充。
相同的规则适用于 printf()
,请参阅 C99 7.19.6.3:2
最佳答案
程序可以有或没有未定义的行为取决于实现的特征。
例如,执行的程序
int x = 32767;
x++;
(并且在其他方面已明确定义)在 INT_MAX > 32767 的实现上具有明确定义的行为,否则具有未定义的行为。
您的程序:
#include <stdio.h>
int main(void)
{
char a='A';
printf("%c\n",a);
return 0;
}
对于 INT_MAX >= CHAR_MAX
的任何托管实现都有明确定义的行为。在任何此类实现中, 'A'
的值晋升为int
,这就是%c
预计。
如果INT_MAX < CHAR_MAX
(这意味着 char
是无符号的,并且 CHAR_BIT >= 16
), a
的值晋升为unsigned int
。 N1570 7.21.6.1p9:
If any argument is not the correct type for the correspondingconversion specification, the behavior is undefined.
暗示这有未定义的行为。
实际上,(a) 这样的实现很少见,可能不存在(我听说过的 CHAR_BIT > 8
的唯一现有 C 实现是针对 DSPs 的,并且这样的实现很可能是独立的),并且 (b)任何此类实现都可能被设计为优雅地处理此类情况。
关于c - 在 printf 需要 int 的地方给 printf 一个 char 参数是 UB 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63908544/
我想知道以下语句在 C 中会打印什么? printf("hello\n") || (printf("goodbye\n") || printf("world\n")); 我通常习惯于使用“cout”在
这是我目前正在学习的系统编程类(class)的幻灯片: catch_child 是 SIGCHLD 处理程序。输出与代码如何对应?为什么没有打印一些“Child #x started”消息? 最佳答案
这有点像拼图……我刚刚又回到了C,打算这次掌握它。所以我一直在阅读 The C Programming Language ,我得到了这个声明: Among others, printf also re
如何使用 printf 在字符串末尾附加空格? 我找不到任何在右侧附加空格的示例。 A similar question我发现使用 printf改为在字符串的左侧添加空格。 最佳答案 使用负数左对齐(
我想通过 usart 从 stm32f405 注销。 在我的 syscall.c 文件中,我实现了通过 usart 打印的功能: int _write(int file, char *ptr, int
我想定义一个记录器函数,比如 myPutStrLn = putStrLn . (++) "log: " main = do myPutStrLn "hello" 这很好。现在我想用 printf 格式
Printf module API详细介绍了类型转换标志,其中: %B: convert a boolean argument to the string true or false %b: conv
@H2CO3 这是我的主要代码: #pragma OPENCL EXTENSION cl_ amd_ printf : enable #define PROGRAM_FILE "matvec.cl"
Printf module API详细介绍了类型转换标志,其中: %B: convert a boolean argument to the string true or false %b: conv
您可以使用 printf 字段宽度说明符截断字符串: printf("%.5s", "abcdefgh"); > abcde 不幸的是,它不适用于数字(将 d 替换为 x 是相同的): printf(
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 4 年前。 Improve th
我遇到了我见过的最奇怪的错误之一。 我有一个简单的程序,可以打印多个整数数组。 对数组进行排序,然后打印...... place_in_buf(n100, 100); insertion(10
我的程序是每隔一段时间获取文件大小并显示它以记录任何更改。由于某种原因,执行下面的代码挂起,只为我提供了一个光标。没有打印或显示任何内容。 代码: #include #include #inclu
printf("It is currently %s's turn.\n", current->name); 我想知道为什么在 %s 之后打印出额外的换行符。我知道C 中的字符串总是以\0 结尾。没有
这个问题已经有答案了: printf anomaly after "fork()" (3 个回答) fork() in c using printf [duplicate] (2 个回答) 已关闭 9
我对编程很陌生。 我正在尝试编写一个程序,从数组中调用水果的价格。但我希望代码在写价格之前也写水果的名称。如果我键入 2,如何使输出为“Orange price : 10”而不仅仅是 price :
这个问题在这里已经有了答案: How do I print a non-null-terminated string using printf? (2 个答案) 关闭 7 年前。 例如,我有一个字符
我有一个 atmel UC3-L0 和罗盘传感器。现在我安装 AtmelStudio 并将一些演示代码下载到电路板中。但是我不知道演示代码中的函数 printf 会在哪里出现数据。我应该如何获取数据?
我有一个 atmel UC3-L0 和罗盘传感器。现在我安装 AtmelStudio 并将一些演示代码下载到电路板中。但是我不知道演示代码中的函数 printf 会在哪里出现数据。我应该如何获取数据?
嗨,我是 C 世界的新手,我的代码确实有些奇怪。目标是创建一个函数,可以在开头和结尾处用空格和/或制表符修剪字符串。我无法使用字符串库。 问题是我的代码中有一个 printf 只是用于测试,它的工作非
我是一名优秀的程序员,十分优秀!