程序:
#ifndef PRINTF_H
#define PRINTF_H
#include "my_put_char.h"
int my_printf(char *str, ...);
#endif
这是我的函数的头文件.
#include <stdio.h>
#include "my_put_char.h"
void my_put_char(char c)
{
fwrite(&c, sizeof(char), 1, stdout);
}
这是我的putchar实现(my_put_char.c).
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include "printf.h"
int my_printf(char *str, ...)
{
if(str == NULL)
return 0;
int i;
char a;
va_list print;
va_start(print,str);
for(i = 0; str[i] ; i++)
{
if(str[i] == '%')
{
i++;
switch(str[i])
{
case 'c':
a = va_arg(print, char);
my_put_char(a);
break;
}
}
}
va_end(print);
return 0;
}
最后,这是我的printf实现的一部分.
我正在测试%c以显示一个字符.
当我做my_print(“%c”,’d’);来自main.c
编译并显示d.
但是当我做my_print(“%c”,“ hi”); ,它仍然会编译并显示一个数字.
题:
之后(或之前)编写一个= va_arg(print,char);有没有办法检查我的输入是否为其他数据类型?
如果我的输入是其他数据类型,我正在尝试显示错误.
我在这个问题上呆了2天,找不到任何答案.
非常感谢您的参与!
解决方法:
when I do
my_print("%c", "hi");
, it still compiles and displays a number
您有大约undefined behavior,所以是scared.您的my_printf会使用错误类型的参数调用va_arg(期望char提升为int,得到char *).
为了解释正在发生的事情,您应该深入了解实现细节(例如使用gcc -Wall -fverbose-asm -O -S查看汇编代码;研究processor、instruction set architecture、application binary interface和calling conventions).您不想这样做,这可能要花费数年并且不可复制.
立即阅读绝对Lattner’s blog on UB!
您还可以在gcc中使用一些function attributes.不要忘记编译所有警告和调试信息(gcc -Wall -Wextra -g)
after writing
a = va_arg(print, char);
Is there a way to check whether my input is a different data type?
不,不是,并非总是如此.但是format函数属性可以提供帮助.您还可能花费数月的时间使用自己的plugin或某些GCC MELT扩展名自定义GCC(这不值得花时间).请注意070012和Rice’s Theorem(它们使static源代码program analysis如此具有挑战性).另请参阅源分析工具,如Frama-C.
I’m implementing printf function
BTW研究C standard library的现有free software实现的源代码(例如GNU glibc和musl-libc)可能是鼓舞人心的;它们基于070221.
标签:printf,c-3,linux 来源: https://codeday.me/bug/20191110/2016064.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。