新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1、值传递
成都创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于网站设计制作、做网站、娄烦网络推广、微信小程序开发、娄烦网络营销、娄烦企业策划、娄烦品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;成都创新互联公司为所有大学生创业者提供娄烦建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
void swap(int x,int y)
{ int temp = x;
x = y;
y = temp;
}void main()
{
int a = 10, b = 20;
swap(a, b);
}
执行后,并不会交换。
2、引用传递
void swap(int x,int y)
{ int temp = x;
x = y;
y = temp;
}void main()
{
int a = 10, b = 20;
swap(a, b);
printf("a=%d\nb=%d\n", a, b);
}
执行后,发生交换。
3、指针传递
void swap(int *x,int *y)
{ int temp = *x; *x = *y; *y = temp;
}void main()
{
int a = 10, b = 20;
swap(a, b);
printf("a=%d\nb=%d\n", a, b);
}
执行后,发生交换。
参数传递只有上面三种,但是如果加上数组,就会产生几种新形式。
首先,明确数组型变量名本身只是该数组所占存储空间的首地址:
int a[3] = { 1, 2, 3 }; int *p = a; //等价于下行 //int *p = a[0];
printf("%d", *p);
典型的数组做参数。
void fun(char s[]){ for (int i = 0; s[i] != '\0'; i++)
printf("%c", s[i]);
}void main()
{ char str[] = "Hello World!";
fun(str);
}
函数调用时,这里系统不会为形参分配数组存储空间,而是仅仅分配一个存放数组地址(第一个元素地址)的存储空间,此后,将实参数组的首地址传递给形参变量。
其实本质与下相同,只不过还是数组形式的(数组名代替指针)。
既然数组型变量名本身只是该数组所占存储空间的首地址,我们当然可以用指针做形参来接收数组实参。
void fun(char *p){ while (*p)
{
printf("%c", *p);
p++;
}
}void main()
{ char str[] = "Hello World!";
fun(str);
}
不过问题是如果这样,无法把握数组结束(除非知道数组长度)。而对于字符数组(上例),由于字符串末尾有结束标志'\0'(ascii码正好是0),所以就很容易利用指针来判断字符串是否结束。
扩展资料:
调用带参数的函数:
在调用函数时,可以向其传递值,这些值被称为参数。
这些参数可以在函数中使用。
可以发送任意多的参数,由逗号 (,) 分隔:
myFunction(argument1,argument2)。
当声明函数时,请把参数作为变量来声明:
function myFunction(var1,var2){这里是要执行的代码}。
变量和参数必须以一致的顺序出现。第一个变量就是第一个被传递的参数的给定的值,以此类推。
按值传递参数:
按值传递参数时,是将实参变量的值复制一个到临时存储单元中,如果在调用过程中改变了形参的值,不会影响实参变量本身,即实参变量保持调用前的值不变。
按值传递参数时,需要在参数名前加"ByVal"关键字。
按地址传递参数:
按地址传递参数时,把实参变量的地址传送给被调用过程,形参和实参共用内存的同一地址。在被调用过程中,形参的值一旦改变,相应实参的值也跟着改变。
如果实参是一个常数或表达式,Visual Basic 6.0会按"传值"方式来处理,按地址传递不需要"ByVal"关键字。
按数组传递参数:
在VB6.0中,允许使用数组作为实参传递到子过程的形参中,数组传递必须采用地址传递的方式来传递参数。数组参数在传递时应注意以下两个方面:
① 在实参和形参列表中只写数组名,忽略维数的定义,但圆括号不能省,当数组作为参数传递时,系统将实参数组的起始地址传给过程,使形参数组也具有与实参数组相同的起始地址,若参数是多维数组,每维以逗号分隔。
② 被调过程可分别通过Lbound和Ubound函数确定实参数组的下界和上界。
参考资料来源:百度百科-参数传递
参考资料来源:百度百科-字符串
c语言编译器默认是不让返回指针类型的,但是返回并没有错,有些情况下会正常执行,当然编译无论是否可以正常执行都会编译。这是因为指针变量在函数中,一旦函数结束,这个指针指向的地址就会作废,suoyi 没意义,故编译器默认返回时会提醒。一般使用加上static使其不销毁。
void表示参数为空,即这个函数不含参数,比如定义一个print函数。
程序执行总是从main函数开始,如果有有其他函数,则完成对其他函数的调用后再返回到主函数,最后由main函数结束整个程序。在执行程序时,由系统调用main函数。main 函数是在程序启动中完成对具有静态存储期的非局部对象的初始化之后被调用的。它是程序在有宿主 (hosted)环境(亦即有操作系统)中所指定的入口点。自立程序(启动加载器,操作系统内核,等等)的入口点则是由实现定义的。
扩展资料:
主函数的两个形参形式中的形参,允许从执行环境中传递任意的多字节字符串(它们通常被称为命令行参数),各个指针 argv.. argv[argc-1] 指向每个这些字符串的第一个字符。argv[0] 是指向一个表示用于执行该程序自身的名字的空结尾多字节字符串(或者当执行环境不支持时,为空字符串 "")的开头字符的指针。
这些字符串是可以改动的,虽然对它们的改动并不会被传回给执行环境:比如可以用 std::strtok 来使用它们。由 argv 所指向的数组的大小至少为 argc+1,其最后一个元素 argv[argc] 保证为一个空指针。
main函数可以不带参数,也可以带参数,这个参数可以认为是 main函数的形式参数。
C语言规定main函数的参数只能有两个,还规定argc(第一个形参)必须是整型变量,argv( 第二个形参)必须是指向字符串的指针数组。加上形参说明后,main函数的函数头应写为:
int main (int argc,char *argv[])
由于main函数不能被其它函数调用,因此不可能在程序内部取得实际值。那么,在何处把实参值赋予main函数的形参呢? 实际上,main函数的参数值是从操作系统命令行上获得的。当我们要运行一个可执行文件时,在DOS提示符下键入文件名,再输入实际参数即可把这些实参传送到main的形参中去。
DOS提示符下命令行的一般形式为:
C:\可执行文件名 参数 参数……
st 传入子程序, st2 从子程序送回.
---------------------------
#include stdio.h
void show_st( char *st, char *st2){
printf("%s\n", st);
strcpy(st2,"new string !!");
}
void main()
{
char st[32]="This is string !";
char new_st[32];
show_st( st[0], new_st[0]);
printf("new string is: %s\n", new_st);
exit(0);
}
程序名abc.exe,带位置参数3个或2个或1个...
abc.exe987654
abc.exe98765
abc.exe987
voidmain(intarg,char*arv[]){}
int型参数,通过字符传递,
charprog_name[60];
intx1,x2,x3;
strcpy(prog_name,arv[0]);//程序名在arv[0]
if(arg=2)sscanf(arv[1],"%d",x1);//传递一个int型
if(arg=3)sscanf(arv[2],"%d",x2);//传递一个int型
if(arg=4)sscanf(arv[3],"%d",x3);//传递一个int型
-------------
浮点计算机参数用if(arg=i)sscanf(arv[i-1],"%f",fi);从字符串里读出来。