导航:首页 > 源码编译 > 编译器不支持可变参数

编译器不支持可变参数

发布时间:2022-07-09 00:34:20

㈠ C语言可变参数传递的问题

voidfun1(inta,intb,constchar*fmt,...);

voidfun2(constchar*fmt,...);.

你注意了,参数传递的可是const类型的,不可以改变哦~

传递出来的args当然也不会有变化。

(奇怪的是你的编译器没有报错吗?晕啊……)

java中方法内的可变参数怎么使用

Java1.5增加了新特性:可变参数:


适用于参数个数不确定,类型确定的情况,java把可变参数当做数组处理。

注意:可变参数必须位于最后一项。当可变参数个数多余一个时,必将有一个不是最后一项,所以只支持有一个可变参数。因为参数个数不定,所以当其后边还有相同类型参数时,java无法区分传入的参数属于前一个可变参数还是后边的参数,所以只能让可变参数位于最后一项。


可变参数的特点:

(1)、只能出现在参数列表的最后;

(2)、...位于变量类型和变量名之间,前后有无空格都可以;

(3)、调用可变参数的方法时,编译器为该可变参数隐含创建一个数组,在方法体中一数组的形式访问可变参数。

publicclassVarable{
publicstaticvoidmain(String[]args){
System.out.println(add(2,3));
System.out.println(add(2,3,5));
}
publicstaticintadd(intx,int...args){
intsum=x;
for(inti=0;i<args.length;i++){
sum+=args[i];
}
returnsum;
}
}

㈢ c语言如何封装一个带有可变参数的方法

需要借用C语言的VA_LIST宏定义,及相关操作来实现可变参数。

VA_LIST所在头文件:#include <stdarg.h>,用法如下:

(1)首先在函数里定义一具VA_LIST型的变量,这个变量是指向参数的指针;

(2)然后用VA_START宏初始化刚定义的VA_LIST变量;

(3)然后用VA_ARG返回可变的参数,VA_ARG的第二个参数是你要返回的参数的类型(如果函数有多个可变参数的,依次调用VA_ARG获取各个参数);

(4)最后用VA_END宏结束可变参数的获取。

以下是一个自定义打印接口的实现:

intmy_printf(constchar*fmt,...)//...表示参数可变
{
va_listargs;//定义va_list
staticchargc_PrintfOutBuff[1000];
va_start(args,fmt);//初始化
vsnprintf((char*)gc_PrintfOutBuff,1000,(char*)fmt,args);//这里没有使用VA_ARG取回单个变量,而是借用vsnprinf一次性读取。
va_end(args);//结束获取
puts("%s",(constchar*)gc_PrintfOutBuff);//使用。
return0;
}

㈣ 为什么编译器不让定义一个没有固定参数项的可变参数函数

标准 C 要求用可变参数的函数至少有一个固定参数项, 这样才可以使用va start()。所以编译器不会接受下面定义的函数:
int f(...)
{
...
}

㈤ 关于Java多态以及可变形参的问题

首先,运行结果的确是sub。但不是因为“编译器认为 int[] arr 和 int...arr 是一样的”。而是因为:①可变参数最终会被编译器以数组的方式存下来;然后调用的时候会优先匹配定长参数的方法,只有当定长参数的方法一个都匹配不上了,才去找非定长参数的方法;②你这个上转型之后其实让base这个实例拥有了两个方法,一个是父类的不定长参数,一个是子类的定长参数方法;

传参不报错是因为判断参数是否合法时匹配到了不定长参数那个方法;然后执行时优先匹配到了定长参数方法(可变参和数组存储方式一致)。编译器并不知道什么可变不可变,就单纯的按照规则去校验调用;

对编译器来说,方法名称和参数列表组成了一个唯一键,称为方法签名,JVM 通过方法签名决定调用哪种重载方法。

JVM 在重载方法中选择合适方法的顺序:

① 精确匹配。

② 基本数据类型自动转换成更大表示范围。

③ 自动拆箱与装箱。

④ 子类向上转型。

⑤ 可变参数。

你这个上转型实现后,即实现了重写,又实现了一种特殊的重载;而编译器编译时检查参数合法性的时候检查到了可变参的方法(你鼠标挪到调用的地方你会看到,编译器提示的你的方法是父类的可变参方法的,因为此时这个参数不是数组,是匹配不到定长参数的子类方法的);


然后编译好具体执行的时候,编译器哪还知道什么定长不定长,就按照优先级去调用方法,自然就把优先级高的子类定长方法调用到了,不存在什么动态绑定。


这里如果你把子类和父类的参数交换(子类是可变参数,父类是数组)那你的调用就报错了,因为可变参兼容数组,但是数组却不兼容可变参,这样就只形成重写而没有重载,然后上转型后就只能调用父类的方法了。就会报错咯

㈥ 关于Java可变参数问题

你好,很高兴回答你的问题。
这就是java可变参数的传参方式,可以直接传一个符合参数数据类型的数组,也可以是用逗号分割的多个符合参数数据类型变量。
如果有帮助到你,请点击采纳。

阅读全文

与编译器不支持可变参数相关的资料

热点内容
喷油螺杆制冷压缩机 浏览:579
python员工信息登记表 浏览:377
高中美术pdf 浏览:161
java实现排列 浏览:513
javavector的用法 浏览:982
osi实现加密的三层 浏览:233
大众宝来原厂中控如何安装app 浏览:916
linux内核根文件系统 浏览:243
3d的命令面板不见了 浏览:526
武汉理工大学服务器ip地址 浏览:149
亚马逊云服务器登录 浏览:525
安卓手机如何进行文件处理 浏览:71
mysql执行系统命令 浏览:930
php支持curlhttps 浏览:143
新预算法责任 浏览:444
服务器如何处理5万人同时在线 浏览:251
哈夫曼编码数据压缩 浏览:426
锁定服务器是什么意思 浏览:385
场景检测算法 浏览:617
解压手机软件触屏 浏览:350