c语言函数指针可变参数 c 可变参数函数

C语言指针变量的赋值和做函数的参数

1、指针变量的赋值,分为定义时赋值(初始化)和单独赋值,如:

成都创新互联公司是一家集网站建设,桦甸企业网站建设,桦甸品牌网站建设,网站定制,桦甸网站建设报价,网络营销,网络优化,桦甸网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

int x ;

int * px=x ; //定义时赋值,也称初始化,注意这里的*是跟随int的,即变量px是int *类型变量! 实际上的赋值语句是px=x ;

int * py ;

py=x ; //单独赋值,将py指向x

*py=10 ; //这里的*,是引用指针中的数据操作符,*跟随的变量必须是指针类型变量,否则会出错! *py就是x,这里相当于x=10;

2、指针变量作为函数的参数时,子函数可以通过指针引用实参地址中的数据,达到修改实参地址中的数据。如:

#include stdio.h

void func( int a, int b, int *pmax )

{

if ( ab ) *pmax=a;

else *pmax=b ;

}

void main()

{

int a=2,b=3,max=0;

func(a,b,max ); //这里将变量max的地址传递到子函数,子函数中通过该地址,可以修改max的值,达到子函数结束后,max能带回运算结果的效果。

printf("max=%d\n", max );

}

c语言中函数可否改变参数值

#include

void

foo(int

x,

int

y,

int

z)

{

printf("x

=

%d

at

[%x]n",

x,

x);

printf("y

=

%d

at

[%x]n",

y,

y);

printf("z

=

%d

at

[%x]n",

z,

z);

}

int

main(int

argc,

char

*argv[])

{

foo(100,

200,

300);

return

0;

}

运行结果:

x

=

100

at

[bfe28760]

y

=

200

at

[bfe28764]

z

=

300

at

[bfe28768]

c程序栈底为高地址,栈顶为低地址,因此上面的实例可以说明函数参数入栈顺序的确是从右至左的。可到底为什么呢?查了一直些文献得知,参数入栈顺序是和具体编译器实现相关的。比如,pascal语言中参数就是从左到右入栈的,有些语言中还可以通过修饰符进行指定,如visual

c++.即然两种方式都可以,为什么c语言要选择从右至左呢?

进一步发现,pascal语言不支持可变长参数,而c语言支持这种特色,正是这个原因使得c语言函数参数入栈顺序为从右至左。具体原因为:c方式参数入栈顺序(从右至左)的好处就是可以动态变化参数个数。通过栈堆分析可知,自左向右的入栈方式,最前面的参数被压在栈底。除非知道参数个数,否则是无法通过栈指针的相对位移求得最左边的参数。这样就变成了左边参数的个数不确定,正好和动态参数个数的方向相反。

因此,c语言函数参数采用自右向左的入栈顺序,主要原因是为了支持可变长参数形式。换句话说,如果不支持这个特色,c语言完全和pascal一样,采用自左向右的参数入栈方式

c语言中指针函数可以改变实参的值吗

c语言中形参与实参的关系是:形参是实参的值副本。无论参数的类型是什么,传递到子函数中的形参只是实参的值。所以,在改变形参变量自身的值时,是与实参无关的。换句话说,形参的改变不会影响到实参。

但,如果参数类型是指针类型,则可以通过对指针变量所指向的地址中的数据进行修改,达到改变实参地址中的数据目的。

因此,使用swap函数进行数据交换时,必须保证两点:

1.

参数必须是指针类型,指向待交换的数据

2.

交换时,必须交换地址中的数据,而不是交换地址本身。

参考代码:

//错误的交换代码1

void swap1( int a, int b ) //参数不是待交换数据的指针

{

int t=a;

a=b;

b=t;

}

//错误的交换代码2

void swap2( int *a, int *b )

{

int *t=a;//交换形参变量本身

a=b;

b=t;

}

//正确的交换代码

void swap( int *a, int *b )

{

int t=*a;//交换形参变量地址中的数据,指针变量不变

*a=*b;

*b=t;

}

C语言如何在可变参数函数中使用printf?

如@psxf91所答,应使用v*系列的函数来实现。对比下printf与vprintf函数原型:

void printf(const char *format, ...);

void vprintf(const char *format, va_list ap);

可以看出二者的差别。vprintf才接收va_list类型,printf接收的是不定参数。

因此,要实现你的要求代码如下:

#include "stdarg.h"

void fun(const char *fmt, ...){

va_list ap;

va_start(ap, fmt);

// ...

vprintf(fmt, ap);

// ...

va_end(ap);

}

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宏结束可变参数的获取。

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

int my_printf(const char *fmt, ...)//...表示参数可变

{

va_list args;//定义va_list

static char gc_PrintfOutBuff[1000];

va_start(args, fmt);//初始化

vsnprintf((char *) gc_PrintfOutBuff, 1000, (char *) fmt, args);//这里没有使用VA_ARG取回单个变量,而是借用vsnprinf一次性读取。

va_end(args);//结束获取

puts("%s",(const char *)gc_PrintfOutBuff);//使用。

return 0;

}


本文标题:c语言函数指针可变参数 c 可变参数函数
文章位置:http://azwzsj.com/article/dodppec.html