成都网站建设设计

将想法与焦点和您一起共享

c语言中的子函数的书写 C语言子函数声明

C语言中的子函数和主函数有什么联系啊?它们是怎么编写的?

主函数:即程序的入口函数,通常是有main字样的函数为主函数。程序执行的时候最先调用的是这个函数。

成都创新互联公司是一家专注于成都网站制作、做网站与策划设计,额尔古纳网站建设哪家好?成都创新互联公司做网站,专注于网站建设十年,网设计领域的专业建站公司;建站业务涵盖:额尔古纳等地区。额尔古纳做网站价格咨询:18980820575

子函数:即用户可以自定义的函数,其实可以写到主函数中,但阅读等很费劲,所以很多代码提到子函数中实现,让代码可读性很强,更精练。

因此,主函数必须有,且可以调用子函数,这是编程语言决定的。子函数可有可没有,子函数可以被主函数调用,也可以被其他子函数调用。

主函数:

返回值类型

main(参数)

int

main()

{

aaa();

}

子函数

void

aaa()

{

}

C语言编写子函数

0分。。。自己调吧。

#include stdio.h

int IsPrime(unsigned int n){

unsigned int i;

for(i=2;in;i++){//对大于1小于n的数进行循环

if(n%i == 0){//如果期间有能整除的数,直接返回0

return 0;

}

}

return 1;//返回1

}

int IsMPrime(unsigned int n){

if(IsPrime(n) ==0){//如果此数本身不是素数直接返回0

return 0;

}

unsigned int p;

unsigned int x;

p=0;

x=n+1;

wihle(x !=1){//求出比x大且与x最近的2的p次方中的p

x=x1;

p++;

}

if(pow(2,p) != n+1){//如果此数+1不是2的p次方,则直接返回0

return 0;

}

return IsPrime(p);//判断p是否为素数,返回判断值

}

int main(){

unsigned int m;

scanf("%d”,m);

if(m 1000){//为了防止输入的数太大导致机器死掉,限定输入的数小于1000。

return 0;

}

for(;m0;m--){//对大于0,小于输入数的整数挨个进行判断

if(IsMPrime(m) ==1){//如果是梅森素数直接打印

printf("%d,",m);

}

}

return 0;//结束程序

}

C语言,这个子函数该怎么写啊?

倒数第二个参数很容易理解吧,就是告诉你调用该函数后实际向文件中写了多少字节,这个值和你指定的要写入多少字节不一定相等,因为如果出错或者执行异步写操作的话,这个值不会等于你指定的要写入的字节数。你要做的就是传递一个dword变量地址,函数会将实际写入的字节数设为该变量的值,调用结束后,检查该变量的值即可知道实际写入了多少字节。

最后一个参数是一个overlaapped结构体指针,它指出,如果你在打开文件(调用createfile或socket创建函数等)时

打开方式指定了file_flag_overlapped标记,那么你需要传递一个overlaapped结构体的地址,如果没有指定该标记,则传递null即可,一般直接传递null,只有在需要异步操作时,才需要指定。

可以写出一个常规调用:

handle

hfile=createfile(……);

tchar

buf[255];//定义一个buf用于提供写入到文件的数据//调用一些函数填充buf,此处省略,也可以是一个外部buf,里面有内容就不用填充了。

dword

bytestowrite=255;

dword

byteswritten=0;

if(!writefile(hfile,buf,bytestowrite,byteswritten,null))

{

//……调用失败

}

C语言中写子函数时候怎么确定子函数类型

函数定义的一般形式 1.无参函数的一般形式 类型说明符 函数名() { 类型说明 语句 } 其中类型说明符和函数名称为函数头。 类型说明符指明了本函数的类型,函数的类型实际上是函数返回值的类型。 该类型说明符与第二章介绍的各种说明符相同。 函数名是由用户定义的标识符,函数名后有一个空括号,其中无参数,但括号不可少。{} 中的内容称为函数体。在函数体中也有类型说明, 这是对函数体内部所用到的变量的类型说明。在很多情况下都不要求无参函数有返回值, 此时函数类型符可以写为void。 我们可以改为一个函数定义: void Hello() { printf ("Hello,world \n"); }  这里,只把main改为Hello作为函数名,其余不变。Hello 函数是一个无参函数,当被其它函数调用时,输出Hello world字符串。 2.有参函数的一般形式 类型说明符 函数名(形式参数表) 型式参数类型说明 { 类型说明 语句 } 有参函数比无参函数多了两个内容,其一是形式参数表, 其二是形式参数类型说明。在形参表中给出的参数称为形式参数, 它们可以是各种类型的变量, 各参数之间用逗号间隔。在进行函数调用时,主调函数将赋予这些形式参数实际的值。 形参既然是变量,当然必须给以类型说明。例如,定义一个函数, 用于求两个数中的大数,可写为: int max(a,b) int a,b; { if (ab) return a; else return b; } 第一行说明max函数是一个整型函数,其返回的函数值是一个整数。形参为a,b。第二行说明a,b均为整型量。 a,b 的具体值是由主调函数在调用时传送过来的。在{}中的函数体内, 除形参外没有使用其它变量,因此只有语句而没有变量类型说明。 上边这种定义方法称为“传统格式”。 这种格式不易于编译系统检查,从而会引起一些非常细微而且难于跟踪的错误。ANSI C 的新标准中把对形参的类型说明合并到形参表中,称为“现代格式”。 例如max函数用现代格式可定义为: int max(int a,int b) { if(ab) return a; else return b; } 现代格式在函数定义和函数说明(后面将要介绍)时, 给出了形式参数及其类型,在编译时易于对它们进行查错, 从而保证了函数说明和定义的一致性。例1.3即采用了这种现代格式。 在max函数体中的return语句是把a(或b)的值作为函数的值返回给主调函数。有返回值函数中至少应有一个return语句。 在C程序中,一个函数的定义可以放在任意位置, 既可放在主函数main之前,也可放在main之后。例如例1.3中定义了一个max 函数,其位置在main之后, 也可以把它放在main之前。 修改后的程序如下所示。 int max(int a,int b) { if(ab)return a; else return b; } void main() { int max(int a,int b); int x,y,z; printf("input two numbers:\n"); scanf("%d%d",x,y); z=max(x,y); printf("maxmum=%d",z); } 现在我们可以从函数定义、 函数说明及函数调用的角度来分析整个程序,从中进一步了解函数的各种特点。程序的第1行至第5行为max函数定义。进入主函数后,因为准备调用max函数,故先对max函数进行说明(程序第8行)。函数定义和函数说明并不是一回事,在后面还要专门讨论。 可以看出函数说明与函数定义中的函数头部分相同,但是末尾要加分号。程序第12 行为调用max函数,并把x,y中的值传送给max的形参a,b。max函数执行的 结果 (a或b)将返回给变量z。最后由主函数输出z的值。 函数调用的一般形式前面已经说过,在程序中是通过对函数的调用来执行函数体的,其过程与其它语言的子程序调用相似。C语言中, 函数调用的一般形式为: 函数名(实际参数表) 对无参函数调用时则无实际参数表。 实际参数表中的参数可以是常数,变量或其它构造类型数据及表达式。 各实参之间用逗号分隔。'Next of Page在C语言中,可以用以下几种方式调用函数: 1.函数表达式 函数作表达式中的一项出现在表达式中,以函数返回值参与表达式的运算。这种方式要求函数是有返回值的。例如: z=max(x,y)是一个赋值表达式,把max的返回值赋予变量z。'Next of Page 2.函数语句 函数调用的一般形式加上分号即构成函数语句。例如: printf ("%D",a);scanf ("%d",b);都是以函数语句的方式调用函数。 3.函数实参 函数作为另一个函数调用的实际参数出现。 这种情况是把该函数的返回值作为实参进行传送,因此要求该函数必须是有返回值的。例如: printf("%d",max(x,y)); 即是把max调用的返回值又作为printf函数的实参来使用的。在函数调用中还应该注意的一个问题是求值顺序的问题。 所谓求值顺序是指对实参表中各量是自左至右使用呢,还是自右至左使用。 对此, 各系统的规定不一定相同。在3.1.3节介绍printf 函数时已提 到过,这里从函数调用的角度再强调一下。 看例5.2程序。 void main() { int i=8; printf("%d\n%d\n%d\n%d\n",++i,--i,i++,i--); } 如按照从右至左的顺序求值。例5.2的运行结果应为: 8 7 7 8 如对printf语句中的++i,--i,i++,i--从左至右求值,结果应为: 9 8 8 9 应特别注意的是,无论是从左至右求值, 还是自右至左求值,其输出顺序都是不变的, 即输出顺序总是和实参表中实参的顺序相同。由于Turbo C现定是自右至左求值,所以结果为8,7,7,8。上述问题如还不理解,上机一试就明白了。函数的参数和函数的值 一、函数的参数 前面已经介绍过,函数的参数分为形参和实参两种。 在本小节中,进一步介绍形参、实参的特点和两者的关系。 形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。实参出现在主调函数中,进入被调函数后,实参变量也不能使用。 形参和实参的功能是作数据传送。发生函数调用时, 主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。 函数的形参和实参具有以下特点: 1.形参变量只有在被调用时才分配内存单元,在调用结束时, 即刻释放所分配的内存单元。因此,形参只有在函数内部有效。 函数调用结束返回主调函数后则不能再使用该形参变量。 2.实参可以是常量、变量、表达式、函数等, 无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值, 以便把这些值传送给形参。 因此应预先用赋值,输入等办法使实参获得确定值。 3.实参和形参在数量上,类型上,顺序上应严格一致, 否则会发生“类型不匹配”的错误。 4.函数调用中发生的数据传送是单向的。 即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。例5.3可以说明这个问题。 void main() { int n; printf("input number\n"); scanf("%d",n); s(n); printf("n=%d\n",n); } int s(int n) { int i; for(i=n-1;i=1;i--) n=n+i; printf("n=%d\n",n); } 本程序中定义了一个函数s,该函数的功能是求∑ni=1i 的值。在主函数中输入n值,并作为实参,在调用时传送给s 函数的形参量n( 注意,本例的形参变量和实参变量的标识符都为n, 但这是两个不同的量,各自的作用域不同)。 在主函数中用printf 语句输出一次n值,这个n值是实参n的值。在函数s中也用printf 语句输出了一次n值,这个n值是形参最后取得的n值0。从运行情况看,输入n值为100。即实参n的值为100。把此值传给函数s时,形参 n 的初值也为100,在执行函数过程中,形参n的值变为5050。 返回主函数之后,输出实参n的值仍为100。可见实参的值不随形参的变化而变化。


分享文章:c语言中的子函数的书写 C语言子函数声明
链接分享:http://chengdu.cdxwcx.cn/article/hgggoi.html