首页
学习
活动
专区
工具
TVP
发布
您找到你想要的搜索结果了吗?
是的
没有找到

printf的归宿-数据打印到哪儿了

近日在一次测试Linux内核路由查找算法的过程中,发现一个printf语句竟然能将性能降低2/3。...当然是UNIX的相关标准以及Linux的具体实现代码。既然原理来自于Linux的代码,为何不贴出来分析一下呢?...对于大多数的人而言,如果想知道printf或者任何其它的接口的原理,肯定不会去摆开架势做出一副要先了解Linux内核架构,C库架构作为前置知识,然后去跟踪调试其实现。...小小的printf下面竟然藏着如此多的内容,并且很可能就是它成了你的程序的性能瓶颈,因为最底层的影响因素往往是不可控的。那么是不是就是意味着我要建议大家从来不用printf打印呢?...但是为何不把打印这种事交给本机的另一个进程呢?事实上,几乎所有的需要记录日志的系统都是这么做的,而syslog则迎合了这个思想。

85830

如何优雅地将printf打印保存在文件中?

我们都知道,一般使用printf打印都会直接打印在终端,如果想要保存在文件里呢?我想你可能想到的是重定向。...例如: $ program > result.txt 这样printf的输出就存储在result.txt中了。相关内容可以参考《如何理解Linux shell中“2>&1”》。...写文件 你可能会想,那不用printf,直接将打印写入到文件不就可以了?...但是本文并不是说明如何实现一个logging功能,而是如何将printf的原始打印保存在文件中。...有些后台进程有自己的日志记录方式,而不想让printf的信息打印在终端,因此可能会关闭。 总结 文本旨在通过将printf打印保存在文件中来介绍重定向,以及0,1,2文件描述符。

9K31

再议printf函数

System.out.printf()是在JDK1.5版开始引入的方法,即在JDK1.5以后的版本才可以使用此函数,printf 方法有 printf(Stringformat, Object ......args) 和 printf(Locale l, String format, Object... args) 两种重载方式。...目前printf支持以下格式:           %c        单个字符           %d        十进制整数           %f        十进制浮点数           ...比如: main(){ inta = -1; printf("%d, %o",a,a); } 运行结果: -1, 177777 3.x格式:以无符号十六进制形式输出整数。...%s:例如:printf("%s","CHINA")输出"CHINA"字符串; 6.2.%ms:输出的字符串占m列,如字符串本身长度大于m,则突破m的限制,将字符串全部输出。

66540

printf漏洞介绍

printf(format,) 1、概念 printf接受变长的参数,其中第一个参数为格式化字符串,后面的参数在实际运行时将与格式化字符串中特定的子字符串进行对应,将格式化字符串中的特定字串...2、漏洞成因 printf函数在执行时,首先进行格式化字符串的解析–从栈(或者寄存器)获取参数并与符号说明进行匹配,然后将匹配的结果输出到屏幕上,那么 ,如果格式化字符串中的符号声明与栈上参数不能正确匹配...而本书,printf也就是一个有力的攻击武器,我们可以通过控制字符串的值来实现更多的泄露或者完成个高级的利用。...3、实例代码 gcc编译之后用gdb打开 我们可以看到红框内edx是“My name is %s”,这个时候注意我们的代码,printf后面是没有跟参的,在本该压参的位置没有参数,导致了压入的是“...我们看到红框呢内,程序开始调用printf函数了,我们的格式是给了,但是var这个参数是什么我们没有给,所以他就会到esp,高4位的地方去取值 所以说这个是残缺的程序,那我们来帮助他完成。

9710
领券