利用可变参实现fprintf函数

#include <stdio.h>
#include <stdarg.h>
/*
可变参相关接口
typedef char * va_list ;
void va_start (va_list ap , prev_param) ;
type va_arg(va_list ap , type) ;
void va_end(va_list ap);
*/
int myfprintf(FILE* fp, char* fmt, ...)
{
     int ret = 0;
     va_list args;  //va_list是一个字符串指针,用于获取不确定个数的参数
     va_start(args,fmt); //读取可变参数的过程其实就是在堆栈中,使用指针,遍历堆栈段中
	 //的参数列表,从低地址到高地址一个一个的把参数内容读出来的过程 

	 //该函数会根据参数fmt字符串来转换格式并格式化数据,然后将结果输出到参数Stream指定的文件中
	 //直到出现字符串结束的\0为止。
     ret = vfprintf(fp, fmt, args);
     //获取完所有参数之后,为了避免发生程序瘫痪,需要将 ap指针关闭,其实这个函数相当于将args设置为NULL
     va_end(args);
     return ret;
}

int main(void)
{
	myfprintf(stdout,"hello world\n");
	return 0 ;
}

运行结果:

时间: 2024-10-13 13:54:20

利用可变参实现fprintf函数的相关文章

利用Thunk让C++成员函数变回调函数

Windows API经常需要回调函数,而在C++开发中面向对象当行其道,若能让C++类的成员函数成为回调函数,简直就是大善!但是C++成员函数都隐含了一个this指针用于指向当前的对象.要实现回调确实不容易. 我大约一年前就接触到Thunk技术,甚至也看过利用Thunk实现将成员函数变成回调函数的例子.但是我实在没了解过C++汇编后的样子,很容易钻了牛角尖,看都看不懂,直接用他们的程序又不敢,毕竟出错后不好处理.前端时间偶尔想起Thunk技术,对未懂技术老这样悬着很可能影响自己的程序员生涯的,

NodeJS中利用Promise来封装异步函数

这篇文章主要介绍了NodeJS中利用Promise来封装异步函数,使用统一的链式API来摆脱多重回调的噩梦,非常的实用的小技能,希望小伙伴们能够喜欢 在写Node.js的过程中,连续的IO操作可能会导致"金字塔噩梦",回调函数的多重嵌套让代码变的难以维护,利用CommonJs的Promise来封装异步函数,使用统一的链式API来摆脱多重回调的噩梦. Node.js提供的非阻塞IO模型允许我们利用回调函数的方式处理IO操作,但是当需要连续的IO操作时,你的回调函数会多重嵌套,代码很不美观

利用jQuery的$.event.fix函数统一浏览器event事件处理_jquery

比如得到触发事件的元素引用在IE浏览器下是:event.srcElement,在FF浏览器下则是:event.target,另外又比如在FF浏览器下得到光标相对页面的位置是event.pageX,而IE浏览器下的处理方式又是不一样的,当然还有一些像"阻止事件冒泡"以及"取消浏览器默认行为"等,不同浏览器也有不同的处理方式,如果我们要使JavaScript在不同的浏览器下能正常处理事件代码,就要分别进行判断处理.现在jQuery为我们提供了统一兼容处理函数$.even

C语言之可变参实现scanf函数

既然有printf函数可变参实现,那就一定有scanf函数的可变参实现.废话不多说,源码奉上: 本源码不过多分析,如要明白原理,请翻本博客以往的文章看说明. 欢迎关注新浪微博:http://weibo.com/u/1896293701/home?topnav=1&wvr=6 #include <stdio.h> #include <stdarg.h> int myscanf(const char *fmt , ...) ; int main(void) { int num

NodeJS中利用Promise来封装异步函数_node.js

 在写Node.js的过程中,连续的IO操作可能会导致"金字塔噩梦",回调函数的多重嵌套让代码变的难以维护,利用CommonJs的Promise来封装异步函数,使用统一的链式API来摆脱多重回调的噩梦. Node.js提供的非阻塞IO模型允许我们利用回调函数的方式处理IO操作,但是当需要连续的IO操作时,你的回调函数会多重嵌套,代码很不美观,而且不易维护,而且可能会有许多错误处理的重复代码,也就是所谓的"Pyramid of Doom". 复制代码 代码如下: st

利用CDONTS发送邮件的ASP函数

<%'Last Updated By Recon On 05/14/2001'On Error Resume Next '利用CDONTS组件在Win2k上发送邮件 '发送普通邮件SendMail "admin@ny.com", "iamchn@263.net", "Normal Mail!", "Please check the attatchment!", 2, 0, "C:\Love.txt"

利用Objective-C运行时hook函数的三种方法

方法一,hook已有公开头文件的类: 首先写一个Utility函数: #import <objc/runtime.h> void exchangeMethod(Class aClass, SEL oldSEL, SEL newSEL) { Method oldMethod = class_getInstanceMethod(aClass, oldSEL); assert(oldMethod); Method newMethod = class_getInstanceMethod(aClass,

javascript下利用arguments实现string.format函数_javascript技巧

下面摘抄一下源码,深入分析一下他的设计实现思路: 复制代码 代码如下: function format(string) { var args = arguments; var pattern = new RegExp("%([1-" + arguments.length + "])", "g"); return String(string).replace(pattern, function(match, index) { return args

利用jdk6的endpoint.pulish函数能将web服务发布到非本地的服务器上吗??

问题描述 请问各位:Endpoint.publish("http://localhost:8080/jwsService/sh",newjwsService());是将服务发布到本地的jdk6自带的web容器中但是我将地址改为服务器地址http://172.16,16.2:8080,报Cannotassignrequestedaddress:bind错误,172.16.16.2上安装的是linux版的jdk6.请问各位是什么原因呢??谢谢指教