1A 2D
都正确的原因是,p=f时会进行隐式类型转换,f被转换成指针类型
p=&f我就不解释了,指针赋值很明显
再一个void f( ) { };不是声明,是定义
void f();这才是声明
下面两个不会
形参和实参的区别
形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。
实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
1形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。
2实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。
3实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。
4函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。
5当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。
char match (chars,char ch1,char ch2)
函数各部分的含义:
第一个char,一般是代表函数的返回值是一个字符。但是它后面有一个,应该把char和连起来看,就是char了。
那么,第一个就是char,代表函数的返回值是一个字符指针(地址)。
match是函数的名字。
括号内是函数的参数,多个参数用逗号分隔。本例共有3个参数:chars,char ch1,char ch2,第一个是s,类型为char型(字符指针型),后两个ch1、ch2都是char型(字符型)。
到这儿,你就知道去掉match前的为什么就不对了。
另外,括号里参数类型(如包含指针)跟函数返回值的类型无关。函数名前加不加只与函数返回值的类型有关。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)