1、函数就是一系列C语句的集合,为了完成某个会重复使用的特定功能。需要该功能的时候,直接调用该函数即可,不用每次都堆叠一大堆的代码。需要修改该功能的时候,也只要修改和维护这一个函数即可。
2、C语言中,数学函数是函数的一种。指专门进行数学运算的函数,一般都在<mathh>头文件下,数学函数列表:
1)int abs(int i); 求整数的绝对值。
2)long labs(long n); 求长整型数的绝对值。
3)double fabs(double x); 求实数的绝对值。
4)double floor(double x); 求不大于x的最大整数,它相当于数学函数[x]。
5)double ceil(double x); 求不小于x的最小整数。
6)double sqrt(double x); 求x的平方根。
7)double log10(double x); 求x的常用对数。
8)double log(double x); 求x的自然对数。
9)double exp(double x); 求欧拉常数e的x次方。
10)double pow10(int p); 求10的p次方。
11)double pow(double x, double y); 求x的y次方。
12)double sin(double x); 正弦函数。
13)double cos(double x); 余弦函数。
14)double tan(double x); 正切函数。
15)double asin(double x); 反正弦函数。
16)double acos(double x); 反余弦函数。
17)double atan(double x); 反正切函数。
18)double atan2(double x); 反正切函数2。
函数是有返回值的,方法是没有返回值的。有返回值的函数可以通过函数执行的结果不同来对返回值进行设置不同的值。函数外部通过函数不同的返回值来确定函数执行的状态和结果。方法不管执行结果如何除了系统错误,都会一直执行下去。
表达式它是由常量、变量、运算符组合,计算以后返回一个结果值。表达式的结束标志是分号(;),C语言中所有的语句和声明都是用分号结束,在分号出现之前,语句是不完整的。语句与表达式这两者有何区别呢下面就跟着我一起来看看吧。
一、表达式
表达式本身什么事情都不做,只是返回结果值。在程序不对返回的结果值做任何 *** 作的情况下,返回的结果值不起任何作用,表达式的作用有两点,一个是放在赋值语句的右边,另一个是作为函数的参数(以后再介绍)。
表达式返回的结果值是有类型的。表达式隐含的数据类型取决于组成表达式的变量和常量的类型。因此,表达式的返回值有可能是某种大小的整型,或者是某精度的浮点型,或者是某种指针类型。
这里面就有类型转化的问题了,在前面说整型运算的时候也提到过。类型转化的原则是从低级向高级自动转化(除非人为的加以控制)。计算的转换顺序基本是这样的:
字符型-->整型-->长整型-->浮点型-->单精度型-->双精度型
就是当字符型和整型在一起运算时,结果为整型,如果整型和浮点型在一起运算,所得的结果就是浮点型,如果有双精度型参与运算,那么答案就是双精度型了。
强制转换是这样的,在类型说明符的两边加上括号,就把后面的变量转换成所要的类型了。如:
(int) a;
(float) b;
第一个式子是把a转换成整型,如果原先有小数部分,则舍去。
第二个式子是把b转换成浮点型,如果原先是整数,则在后面补0。
每一个表达式的返回值都具有逻辑特性。如果返回值为非0,则该表达式返回值为真,否则为假。这种逻辑特性可以用在程序流程控制语句中。
有时表达式也不参加运算,如:
if(a||b) …………
5>3a++:b++;
当a为真时,b就不参加运算了,因为不管b如何,条件总是真。
二、语句
(一)、赋值语句
其实这个问题,在讲赋值运算符的时候已经讲了一些了。
Amount=1+2;
Total=Counter/3+5;
Area=HeightWidth;
也许你会发现,这些赋值语句很象代数方程,在某些情况下,我们的确可以这样理解,但有时它们是不一样的。看下面:
Num=Num+1;
这显然不是一个等式。
(二)、用逗号分隔开的声明语句
C语言可大多数语言一样,允许用逗号分隔声明语句中的标识符列表,说明这些运算符是同一变量类型。例如:
float Area,Height,Width;
但有些程序员喜欢把标识符写在不同的行上。如:
float Area,
Height,
Width;
这样写至少有一个好处,就是可以在每个标识符后边加上注释。
在声明变量的时候,也可以直接给变量赋值,这叫做变量的初始化。
如:int a;
a=3;
等价于:
int a=3;
我们也让某些变量初始化,某些不初始化,如:
int a=3,b,c=5;
在进行初始化时,初始化表达式可以是任意的(对全局变量和静态变量有区别),由于逗号运算符是从左到右运算的,那么看看这样行不行
int a=3,b=a,c=5;
(三)、标准输入输出语句
Turbo C 20标准库提供了两个控制台格式化输入、输出函数scanf();和printf();这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。scanf() 函数用来从标准输入设备(键盘)上读数据,printf()函数用来向标准输出设备(屏幕)写数据。下面详细介绍这两个函数的用法。
1标准输入语句
scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。其调用格式为:
scanf(<格式化字符串>, <地址表>);
格式化字符串包括以下三类不同的字符;
(1)空白字符:空白字符会使scanf()函数在读 *** 作中略去输入中的一个或多个空白字符。
(2)非空白字符:一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。
(3)格式化说明符:以%开始,后跟一个或几个规定字符,用来确定输出内容格式。
Turbo C 20提供的输入格式化规定符如下:
━━━━━━━━━━━━━━━━━━━━━━━━━━
符号 作用
──────────────────────────
%d 十进制有符号整数
%u 十进制无符号整数
%f 浮点数
%s 字符串
%c 单个字符
%p 指针的值
%x,%X 无符号以十六进制表示的整数
%o 无符号以八进制表示的整数
━━━━━━━━━━━━━━━━━━━━━━━━━━
地址表是需要读入的所有变量的地址,而不是变量本身,取地址符为'&'。各个变量的地址之间同,分开。
例如:
scanf(%d,%d,&i,&j);
上例中的scanf()函数先读一个整型数,然后把接着输入的逗号剔除掉,最后读入另一个整型数。如果,这一特定字符没有找到,scanf()函数就终止。若参数之间的分隔符为空格,则参数之间必须输入一个或多个空格。
说明:
(a)对于各个变量,类型说明符是什么,输入格式化说明符就应该用对应的类型。否则会出现程序错误或输入数据和理想的不一样。
(b)对于字符串数组或字符串指针变量,由于数组名和指针变量名本身就是地址,因此使用scanf()函数时,不需要在它们前面加上& *** 作符。
char p,str[20];
scanf(%s, p);
scanf(%s, str);
具体字符串,指针的知识以后再介绍。
(c)可以在格式化字符串中的%各格式化规定符之间加入一个整数,表示任何读 *** 作中的最大位数。
如上例中若规定只能输入10字符给字符串指针p,则第一条scanf()函数语句变为:
scanf(%10s, p);
程序运行时一旦输入字符个数大于10, p就不再继续读入。
实际使用scanf()函数时存在一个问题, 下面举例进行说明:
当使用多个scanf()函数连续给多个字符变量输入时, 例如:
char c1, c2;
scanf(%c, &c1);
scanf(%c, &c2);
运行该程序,输入一个字符A后回车(要完成输入必须回车),在执行scanf(%c,&c1)时,给变量c1赋值A,但回车符仍然留在缓冲区内,执行输入语句scanf(%c,&c2)时,变量c2输出的是一空行,如果输入AB后回车,那么实际存入变量里的结果为c1为A,c2为B。
要解决以上问题, 可以在输入函数前加入清除函数fflush();(这个函数的使用方法将在本节最后讲述)。
(d)当在格式说明符之间加入''时,表示跳过输入,例如:
scanf(%3d,&a);
当输入12345的时候,前面三个字符跳过去不考虑,最终变量a的值为45。
2标准输出语句
printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:
printf(<格式化字符串>, <参量表>);
其中格式化字符串包括两部分内容:一部分是正常字符,
这些字符将按原样输出;另一部分是格式化规定字符,以%开始,后跟一个或几个规定字符,用来确定输出内容格式。
参量表是需要输出的一系列参数,其个数必须与格式化字符串所说明的输出参数个数一样多,各参数之间用,分开,且顺序一一对应,否则将会出现意想不到的错误。
对于输出语句,还有两个格式化说明符
符号 作用
%e 指数形式的浮点数
%g 自动选择合适的表示法
说明:
(1)可以在%和字母之间插进数字表示最大场宽。
例如: %3d 表示输出3位整型数,不够3位右对齐。
%92f 表示输出场宽为9的浮点数,其中小数位为2,整数位为6,小数点占一位,不够9位右对齐。
%8s 表示输出8个字符的字符串,不够8个字符右对齐。
如果字符串的长度、或整型数位数超过说明的场宽,将按其实际长度输出。但对浮点数,若整数部分位数超过了说明的整数位宽度,将按实际整数位输出;若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五入输出。
另外,若想在输出值前加一些0, 就应在场宽项前加个0。
例如: %04d 表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位。
如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。
例如: %69s 表示显示一个长度不小于6且不大于9的字符串。若大于9,则第9个字符以后的内容将被删除。
(2) 可以在%和字母之间加小写字母l,表示输出的是长型数。
例如: %ld 表示输出long整数
%lf 表示输出double浮点数
(3) 可以控制输出左对齐或右对齐,即在%和字母之间加入一个- 号可说明输出为左对齐,否则为右对齐。
例如: %-7d 表示输出7位整数左对齐
%-10s 表示输出10个字符左对齐
一些特殊规定字符(可以参照前面说的转义字符)
━━━━━━━━━━━━━━━━━━━━━━━━━━
字符 作用
──────────────────────────
\n 换行
\f 清屏并换页
\r 回车
\t Tab符
\xhh 表示一个ASCII码用16进表示
猜你喜欢
1 比较诗意的情感句子
2 表达伤心比较有意义的句子
3 想表达合作成功的语句
4 c语言中逻辑或的用法
5 表达看淡一切的句子
6 表达奋斗的句子
7 五种常见表达句子间关系的词汇
msgbox是函数。
函数与语句的区别:
1、函数是为了完成特定功能而制作的过程。它由一系列的命令及语句构成。函数分成系统函数与自定义函数。msgbox是VB自带的,属于系统函数;如果自己为了完成某种功能而编写的函数,即为自定义函数。
2、语句是函数的构成部件。一条语句一般为一行。它的作用是执行某种命令。如:dim
a
as
integer
该语句表示定义一个数值型变量a,call
msgbox("你好!")
该语句的作用是调用系统对话框。
1、概念不同:
自定义函数诸多限制,有许多语句不能使用,许多功能不能实现。函数可以直接引用返回值,用表变量返回记录集。但是,用户定义函数不能用于执行一组修改全局数据库状态的 *** 作。
存在这样一个表:Temperature(Year, Month, Day, T02, T08, T14, T20),其中Year,Month,Day是时间字段,T02, T08, T14, T20是指2时、8时、14时、20时四个时刻对应的温度值,这些温度值可为空。现在,要求统计2008年5月份的平均温度。
2、查询不同:
SELECT (AVG(T02)+AVG(T08)+AVG(T14)+AVG(T20))/4 FROM Temperature WHERE Year=2008 AND Month=5
如果不考虑空值的话,这样完全正确,但是考虑空值的话,如果根本没有统计02时的温度,那么AVG(T02)将为NULL,然后进行所有运算的结果都将为NULL。这显然是不正确的。
这里可以创建一个自定义函数,然后使用一个SELECT语句即可查询:
SELECT AVG(userAverage(T02,T08,T14,T20)) FROM Temperature WHERE Year=2008 AND Month=5
扩展资料函数限制比较多,如不能用临时表,只能用表变量等,而存储过程的限制相对就比较少。
1、一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2、 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3、 存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
4、 当存储过程和函数被执行的时候,SQL Manager会到procedure cache中去取相应的查询语句,如果在procedure cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。
-函数
Oracle Decode()函数和CASE语句都是我们经常用到的 那么它们的区别在哪里呢下面就为您详细介绍
Oracle Decode()函数和CASE语句的区别 供您参考
首先 举 个简单的例子 简单对比一下这 者的区别
CASE语句
以下是代码片段
SELECT CASE SIGN( ) WHEN THEN Is Positive WHEN THEN Is Negative ELSE Is Zero END FROM DUAL;
后台实现
以下是代码片段
if (SIGN( – ) = ) { Is Positive ; } else if (SIGN( – ) = ) { Is Negative ; }else { ‘Is Zero’ }Decode函数
以下是代码片段
SELECT DECODE(SIGN( – ) Is Positive Is Negative ‘Is Zero’) FROMDUAL后台实现
以下是代码片段
switch ( SIGN( – ) ) { case : Is Positive ; break; case : Is Negative ; break; default : ‘Is Zero’ }在上面的例子中 者似乎都可以实现 但是 在碰到非凡的问题时Decode()要实现起来就相当复杂了
例如
以下是代码片段
SELECT CASE X FIELD WHEN X FIELD < THEN ‘X FIELD < ’ WHEN X FIELD < THEN ‘X FIELD < ’ WHEN X FIELD < THEN ‘X FIELD < ’ ELSE ‘UNBEKNOWN’END FROM DUAL lishixinzhi/Article/program/Oracle/201311/19030
其实根本没有什么复杂的意思,这句话已经说的很清楚了,C语言只有输入输出函数,没有输入输出语句,例如想输出一句Hello World!,你用的是printf("Hello World!");或者是puts("Hello World!");无论你用哪种方式输出,你都用了c库函数提供的输出函数print() ,puts()
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)