A. linux下printf函数为什么没有输出相关的内容
#include<stdio.h>
#include<unistd.h>
int main(void)
{
printf("before execl called\n");
if(-1 == execl("/bin/ls","ls","/","/home",NULL))
{
perror("execl");
return -1;
}
printf("after execl called\n");
return 0;
}
Linux下C语言的printf是C标准I/O库中的格式化输出函数之一,将格式化数据写到标准输出stdout。
1 printf首先把格式化数据写到标准I/O的缓存,可以用setbuf和setvbuf设置缓存选项;
2 调用write系统调用,把标准I/O的缓存数据写到文件描述符STDOUT_FILENO,则标准I/O缓存中的数据就被送到内核缓存;
3 内核把缓存中的数据输出到标准输出stdout对应的文件描述符STDOUT_FILENO。
这是我的理解,基本应该就是这个流程,内核层次上的细节我就不清楚了。
另外:
1 printf返回写入的字节数;
2 printf处理可变参数表使用的是va_list,当然也有相应的vprintf,它的第三个参数就是一个va_list
B. Linux下的一个c程序,程序一遇到printf就出现段错误
程序运行在内存中;
系统在程序运行之前会在内存中先给程序画出一个空间
这个空间有些来存放代码的;有些来存放运行时的变量,还有些....
这个空间有一个区间使用来存放运行时的变量什么的
段错误 就是 程序运行时,变量访问越界一类的问题...
可能出现的原因是:
数组下标越界
动态分配内存的指针被double free了(释放两次了)
C. LINUX下C语言连续的三个printf ,最后一个不执行,程序卡在那里,按ctrl+c继续执行。
可以如一楼那样改,也可以把printf改为fprintf(stderr,"hello world");
printf可能有行缓冲,但stderr是无缓冲.
D. 在linux中使用printf("%02x", md5[i]); 能够打印出32位十六进制的数据如:
定义一个字符数组char pszMd5[20];
memset(pszMd5, 0, 20);
pszMd5[0] = md5[0]
最后追加个字符串结尾符号'\0'就可以了。
数据相同,只是解释方式不一样了。