c语言输出参数
Ⅰ c语言printf()多参数时的输出机制如何
int a;
float b;
char c;
printf("%d,%s,%f",a,c,b);
这样?
Ⅱ c语言中参数表是什么意思
函数的参数分为形参和实参两种。形参出现在函数定义中,在整个函数体内都可以使用,离开该函数则不能使用。实参出现在主调函数中,进入被调函数后,实参变量也不能使用。形参和实参的功能是作数据传送。发生函数调用时,主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
函数的形参和实参具有以下特点:
1. 形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只有在函数内部有效。函数调用结束返回主调函数后则不能再使用该形参变量。
2. 实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使实参获得确定值。
3. 实参和形参在数量上,类型上,顺序上应严格一致,否则会发生类型不匹配”的错误。
4. 函数调用中发生的数据传送是单向的。即只能把实参的值传送给形参,而不能把形参的值反向地传送给实参。 因此在函数调用过程中,形参的值发生改变,而实参中的值不会变化。
Ⅲ C语言函数中什么是输出参数举个简单例子
C里没有类似于C#的指定ref,out的输入输出参数
它是通过不同的传递参数类型决定其输入输出参数的
如果是传值参数,只能用于输入参数
如果是引用或指针类型,则即可用于输入也可用于输出
如 int fun( int a, int& b, int* c )
a 作为输入参数
b和c 可输入也可输出
Ⅳ c语言return和输出参数有什么关系
希望题主能弄清楚以下3个概念:
函数返回值类型:
函数的返回值类型需要在函数定义时指明于函数名左侧,返回值类型决定了函数能够通过return语句返回的值的类型。比如一个函数返回值定义为char型,而函数内部的return语句返回的却是一个float型,那么return语句处就会出错,因为返回的值的类型和事先声明的函数返回值类型不匹配。(举个通俗例子:我让你做完某件事告诉我一个字,结果你做完了却告诉我一个数,那我和你还能好好沟通吗?)
return语句:
函数执行时遇到return语句则会结束函数,并将return右侧的“量”(变量、常量、字面值等)作为函数的返回值返回给调用方,return右侧返回的这个“量”必须和函数定义时指明的函数返回值类型相匹配(或者能够自动转换,比如函数返回值指明为double型,函数内部return 1;是没错的,因为1是个整数但可以自动转换为double型的1.0)
输出参数
输出参数是一个比较“高级”的概念,有时候我们希望函数能够“返回多个值”,但函数返回值永远都只能是一个,那么这时候我们可以通过令函数的参数为“接收返回值”的变量指针来实现“返回多个值”的效果,此时这些“接收返回值”的变量指针就是“输出参数”。举例来说,我们希望一个函数能将一个int数组中的最大值max、最小值min、平均值ave都算出来,但函数的返回值只有能一个,那该怎么办?此时我们就可以利用指针来实现“输出参数”
voidfunc(int*max,int*min,int*ave)
//这个函数返回值是void,但通过3个指针参数,我们实现了将结果“输出”的目的
//只要调用方用3个int型变量来“接收”输出结果即可,这就是“输出参数”
Ⅳ C语言函数中什么是输出参数
C语言中的输出参数应该是指针吧
int max(int a, int b,int *m)//a,b是输入参数,m是输出参数
{
*m = a>b?a:b;
return *m;
}
int main()
{
int a=2,b=3,m;
max(a,b,&m);
printf("max=%d\n",m);
}
Ⅵ 在C语言里,printf怎么输出2个变量
%d是整数的输出标识符。要输出两个变量,用逗号隔开即可。标识符和变量的顺序是相对应的,不能错。输出2个变量的代码修改:
{int a,b,c,sum,sum1;
a=10;
b=20;
c=30;
sum=a+b;
sum1=a+b+c;
printf ("sum=%d/nsum1=%d/n",sum,sum1);}
(6)c语言输出参数扩展阅读:
变量可以通过变量名访问。在指令式语言中,变量通常是可变的;但在纯函数式语言(如Haskell)中,变量可能是不可变(immutable)的。
在一些语言中,变量可能被明确为是能表示可变状态、具有存储空间的抽象(如在Java和Visual Basic中);但另外一些语言可能使用其它概念(如C的对象)来指称这种抽象,而不严格地定义“变量”的准确外延。
如果按存储占用空间来分,变量可以是整型变量,字符型变量,浮点型变量等。当然还有数组,结构体变量等。
变量的命名规则:
变量名必须以字母或下划线 "_" 开头。
变量名只能包含字母数字字符以及下划线。
变量名不能包含空格。如果变量名由多个单词组成,那么应该使用下划线进行分隔(比如 $my_string),或者以大写字母开头(比如 $myString)。
Ⅶ C语言的输出参数是什么跟返回值有什么关系
1、C语言中,所谓传参一般调用一个函数时,传递过来的参数,否则被调用函数是无法使用调用函数里面的参数的,除了全局参数等。
2、C语言中的返回值一般一return 的形式出现,就是这个函数结束时,会抛出需要返回的一个值。在调用的函数中可以接收。下面我举一个完整的例子来说明这几者的关系。
3、例程:
#include <stdio.h>
int counter(int i);
void main(void)
{
int j,m;
m = 5;
j = counter(m); //此处调用函数counter();并且传入参数,一个int型的m,
//次函数在结束时将返回一个int型,这里用j来接收
printf("返回值为:%d\n",j);
}
int counter(int i) //这里是函数定义,int counter();说明此函数将会返回一个
{ //int型
//counter(int i);表示在调用此函数时需要传入一个int型参数
return i + 1; //此处是函数将要返回的值,传进来的是5,那返回 5 + 1,返回6
}
Ⅷ C语言输入输出语句
c语言输入输出函数
C语言输入输出函数有很多,标准
I/O
函数中包含了如下几个常用的函数:
scanf,printf,getc,putc,getchar,putchar,gets,puts,fgets,fputs,fgetc,fputc,fscanf,fprintf
等.
int scanf(const char *format, arg_list)
scanf
主要从标准输入流中获取参数值,format为指定的参数格式及参数类型,如
scanf("%s,%d",str,icount);
它要求在标准输入流中输入类似"son of bitch,1000"这样的字符串,同时程序会将"son of bitch"给str,1000给icount. scanf函数的返回值为int值,即成功赋值的个数,在上例中如果函数调用成功,则会返回2,所以我们在写程序时,可以通过语句
if(scanf("%s,%d",str,icount) != 2){...}
来判断用户输入是否正确.
int printf(const char *format, arg_list)
printf
主要是将格式化字符串输出到标准输出流中,在stdio.h头文件中定义了标准的输入和输出,分别是stdin,stdout. arg_list可以是变量名,也可以是表达式,但最终都会以值的形式填充进
format中. int getc(FILE *fp) getc主要是从文件中读出一个字符.常用的判断文件是否读取结束的语句为:(ch = getc(fp)) != EOF.EOF为文件结束标志, 定义在stdio.h中,就像EXIT_SUCCESS,EXIT_FAILURE定义在stdlib.h中一样,文件也可以被理解为一种流,所以当fp
为stdin 时,getc(stdin)就等同于getchar()了. int putc(int ch,FILE *fp) putc主要是把符ch写到文件fp中去.如果fp为stdout,则putc就等同于putchar()了.
int getchar(void)
getchar
主要是从标准输入流读取一个字符.默认的标准输入流即stdio.h中定义的stdin.但是从输入流中读取字符时又涉及到缓冲的问题,所以并不是在屏幕中敲上一个字符程序就会运行,一般是通过在屏幕上敲上回车键,然后将回车前的字符串放在缓冲区中,getchar就是在缓冲区一个一个的读字符.当然也可以在while循环中指定终止字符,
如下面的语句:
while ((c = getchar()) != '#')
这是以#来结束的.
int putchar(int ch)
putchar(ch)
主要是把字符ch写到标准流stdout中去.
char * gets(char *str)
gets
主要是从标准输入流读取字符串并回显,读到换行符时退出,并会将换行符省去. int puts(char *str)
puts
主要是把字符串str写到标准流stdout中去,并会在输出到最后时添加一个换行符.
char *fgets(char *str, int num, FILE *fp)
str
是存放读入的字符数组指针,num是最大允许的读入字符数,fp是文件指针.fgets的功能是
读一行字符,该行的字符数不大于num-1.因为fgets
函数会在末尾加上一个空字符以构成一个字符串.
另外
fgets
在读取
到换行符后不会将其省略
.
int fputs(char *str, file *fp)
fputs
将
str
写入
fp.fputs
与
puts
的不同之处是
fputs
在打印时并不添加换行符
.
int fgetc(FILE *fp)
fgetc
从
fp
的当前位置读取一个字符
.
int fputc(int ch, file *fp)
fputc
是将
ch
写入
fp
当前指定位置
.
int fscanf(FILE *fp, char *format,...)
fscanf
按照指定格式从文件中出读出数据
,
并赋值到参数列表中
.
int fprintf(FILE *fp, char *format,...)
fprintf
将格式化数据写入流式文件中
.
http://www.cnblogs.com/yaoleiroyal/archive/
2008
/
04
/
03
/1135819.html
字符串输入:
gets()
char name[20];
printf("Hi,What's your name?\n");
gets(name);
printf("Nice name %s",name);
它使用一个地址把字符串赋予
name
。
char name[20];
char *p;
printf("\nEn,What's your name?\n");
p=gets(name);
printf("%s?Oh,Nice name %s\n",name,p);
get()
的代码使用
return
关键字返回字符串的地址,程序把这个地址分配给指针
p
。
fgets()
fgets()
是为文件
I/O
而设计的,处理键盘输入不是特别方便。
printf("\nHi,What's your name?\n");
p=fgets(name,20,stdin);
printf("%s?Oh,Nice name %s\n",name,p);
*fgets()
的第二个参数说明最大读入的字符数。如果这个参数值为
n
,那么
fgets()
就会读取最
多
n-1
个字符或读完一个换行符为止。两个条件满足任意一个结束。
*fgets()
读取到换行符,就会把它存到字符串里,而不是想
gets()
那样丢弃它。
*fgets()
的第三个参数说明读哪个文件。
从键盘上读数据时,
可以使用
stdin(
代表
standard input)
作为参数。
scanf()
char name1[11], name2[11];
int count;
printf("\nPlease write down 2 names...\n");
count=scanf("%5s %6s",name1,name2);
printf("\nname1:%s\nname2:%s",name1,name2);
scanf()
允许指定输入字符串长度等格式。上面的程序如果输入
"liujiajia
liujiajia",
程序将输出
"name1:liuji
name2:liujia";
字符串输出:
puts()
char str[15]="hello world";
const char *str2="HELLO WORLD";
puts(str);
puts(str2);
puts(&str[5]);
puts(str2+2);
puts()
显示字符串时自动在其后添加一个换行符。
puts(&str[5]);
将输出从
str
的第六个元素开始到字符串结束。
puts(str2+2);
将输出从
str2
的地址向后移动两个字符开始到字符串结束。
fputs()
fputs(str,stdout);
fputs(str2,stdout);
fputs(&str[5],stdout);
fputs(str2+2,stdout);
*fputs()
第二个参数表示要写的文件。可以使用
stdout(
代表
standard output)
作为参数。
*fputs()
不自动输出换行符,这与
puts()
不太相同。
Ⅸ C语言中如何输出各种常量
http://ke..com/view/410546.htm 自己看看网络里面关于printf函数的参数说明就可以了。
输出指说用 %e参数 ,输出整数用%d 输出无符号整数也就是类似1234U这样的无符号整数常量,末尾带U的,可以用%u参数,输出指针用%p
Ⅹ c语言中参数是什么概念
函数的参数分为形参和实参两种。
形参出现在函数定义中,在整个函数体内都可以使用,离开该函数则不能使用。实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
形参和实参的功能是作数据传送,发生函数调用时,主调函数把实参的值传送给被调函数的形参从而实现主调函数向被调函数的数据传送。
举个例子:
定义一个函数s=f(a,b),功能是将a和b的差赋值给s,那么,a和b就是这个函数的两个参数。
(10)c语言输出参数扩展阅读:
C语言的参数传递方式
方法有3种方式:值传递、地址传递、引用传递
tips:
被调用函数的形参只有函数被调用时才会临时分配存储单元,一旦调用结束占用的内存便会被释放
值传递和地址传递,传递的都是实参的一个拷贝
C语言中实参和形参之间的数据传递是单向的“值传递”,单向传递,只能由实参传给形参,反之不行
输出格式并没有选择%p而是选择了%d,因为十进制的数看起来更直观。
值传递
如果只是传递值的话:
#include <stdio.h>
//值传递传值
void swap( int x, int y);
int main()
{
int a=2,b=3;
printf("before:实参为a,b a=%d,地址为%d b=%d,地址为%d ",a,&a,b,&b);
swap(a,b);
printf("after:实参为a,b a=%d,地址为%d b=%d,地址为%d ",a,&a,b,&b);
return 0;
}
void swap(int x,int y)
{
int tmp;
tmp=x;
x=y;
y=tmp;
printf("inside:形参为x,y x=%d,地址为%d y=%d,地址为%d ",x,&x,y,&y);
}