C++ 中获取 可变形參函数中的參数

#include <iostream>
#include <stdarg.h>

using namespace std;

int ArgFunc(const char * str, ...)
{
	va_list ap;			 // 定义參数列表变量

	va_start(ap, str); 	 // 确定參数位置。表明从 str 開始获取參数

	// 開始获取參数    var_arg(ap, 数据类型)  返回获取的值
	cout<<va_arg(ap, int)<<endl;
	cout<<va_arg(ap, int)<<endl;

	// 由于仅仅传入两个參数。所以这里获取到的数值为 零
	cout<<va_arg(ap, int)<<endl;
	cout<<va_arg(ap, int)<<endl;

	va_end(ap);			// 将參数列表 ap 清零

	return 0;
}

int main()
{

	ArgFunc("func", 10, 20);   // 数据从右往左 压入 栈中 。栈顶元素为 "func"

	return 0;
}

/*****************************************************
*
*         获取可变參数
*
*  1. 包括头文件:#include <stdarg.h>
*  2. 定义 參数列表变量:va_list ap;
*  3. 确定从哪里開始获取数据    va_start(ap, str); 表示在str參数之后開始获取參数。
*  4. 開始获取參数并指明类型,如:va_arg(ap, int); 获取第一个參数。并指明类型为 int
*  5. 清空列表  va_end(ap);
*
******************************************************/

执行结果:

时间: 2024-10-14 17:12:17

C++ 中获取 可变形參函数中的參数的相关文章

C++ 中获取 可变形参函数中的参数

#include <iostream> #include <stdarg.h> using namespace std; int ArgFunc(const char * str, ...) { va_list ap; // 定义参数列表变量 va_start(ap, str); // 确定参数位置,表明从 str 开始获取参数 // 开始获取参数 var_arg(ap, 数据类型) 返回获取的值 cout<<va_arg(ap, int)<<endl; c

在C#中获取如PHP函数time()一样的时间戳

原文:在C#中获取如PHP函数time()一样的时间戳 c#中没有象PHP一样的time()时间戳函数,但有DateTime.Now.Ticks用来计算时间差. 此属性的值为自 0001 年 1 月 1 日午夜 12:00 以来所经过时间以 100 毫微秒为间隔表示时的数字.dotnet下用DateTime.Now.Ticks能够得到精确的时间,单位是10^-7s. 经过实验,发现 long a=(DateTime.Now.Ticks-aa.Ticks)/10000000-8*60*60; tb

从O365中获取users到D365中 使用flow

在我上篇blog中讲解到了怎么用代码把O365 users 获取到D365中. 从O365中获取users到D365中 这几天一直在研究flow, 发现flow可以更简单的完成这个功能. 一开始没有考虑用flow是因为flow获取所有用户的方式比较困难, 需要有个workaround (首先需要把所有用户添加到一个group当中,然后获取group member list) 首先我们需要使用Search for users (v2) 只有V2 版本可以直接获取所有的users 在一个list当中

mysql中获取时间的函数

今天做项目,有一个获取七天前日期的数据的一个需求.然后就百度mysql中关于时间的函数.收集了一些.现记录如下: 参考地址:http://www.w3school.com.cn/sql/sql_dates.asp -- 获取当前时间SELECT NOW() SELECT CURDATE()SELECT CURRENT_DATE()SELECT CURRENT_TIME()SELECT CURRENT_TIMESTAMP()SELECT CURTIME() -- DATE_SUB() 函数从日期减

CI中获取读操作的结果集行数+获取写操作的影响行数

本质:读操作,用mysql_num_rows函数,写操作用mysql_affected_rows函数 mysql_num_rows() 返回结果集中行的数目.此命令仅对 SELECT 语句有效.要取得被 INSERT,UPDATE 或者 DELETE 查询所影响到的行的数目,用 mysql_affected_rows(). CI中的方法: 读操作,获取行数: $query->num_rows() 该函数将会返回当前请求的行数.在本例子中, $query 表示当前 SQL 所产生的请求结果对象:

python中print()函数的“,”与java中System.out.print()函数中的“+”

python中的print()函数和java中的System.out.print()函数都有着打印字符串的功能. python中: print("hello,world!") 输出结果为:hello,world! java中: System.out.print("hello,world!"); 输出结果为:hello,world! 我们可以看到,这两个函数的用法是一样的 print()函数还有这种用法: print("1+1=",1+1) 输出结

spring中获取dao或对象中方法的实例化对象

spring中获取dao的中方法的实例化对象: 1 //获取应用上下文对象 2 ApplicationContext ctx = new ClassPathXmlApplicationContext("spring-config.xml"); 3 //例子:获取dicDao实例 4 dicDao = ctx.getBean(IDicDao.class); //例子2:获取MemcacheAccess的实例: 5 memcachedAccess = ctx.getBean(Memcach

spring boot拦截器中获取request post请求中的参数

最近有一个需要从拦截器中获取post请求的参数的需求,这里记录一下处理过程中出现的问题. 首先想到的就是request.getParameter(String )方法,但是这个方法只能在get请求中取到参数,post是不行的,后来想到了使用流的方式,调用request.getInputStream()获取流,然后从流中读取参数,如下代码所示: String body = ""; StringBuilder stringBuilder = new StringBuilder(); Buf

vROPS中获取虚拟机在VC中的UUID

vROPS中虚拟机对象的ID为resourceID,跟vCenter中虚拟机的UUID是不一致的,因此想要将vROPS中的虚拟机和vCenter中的虚拟机对应肯定不能靠虚拟机名称,而是一定要靠UUID. 下面的示例显示如何通过vROPS API获取虚拟机在vCenter中的UUID 步骤1,获取vROPS Token URL: https://vrops.vmware.com/suite-api/api/auth/token/acquireMethod: POSTContent-Type: ap

vue中this在回调函数中的使用

this在各类回调中使用: 如果是普通函数是没法使用的 所以需要先将this.变量赋值给新的变量,然后才能在回调函数中使用 例如: refund: function (id) { if (!this.url.refund) { this.$message.error("请设置url.refund属性!") return } var that = this; this.$confirm({ title: "确认退款", content: "是否要进行退款?&