C高级预习(6)和C语言基础(1)

课堂笔记:

需强化记忆的有:

  • C语言之父:丹尼斯*里奇
    #:预处理命令
    include:头文件的包含
    <>:把括号里面的内容引入到原文件中
    stdio.h :头文件,是计算机自带的库,可以直接使用
    main:函数名,main()是主函数,C程序源文件有且只能有一个
    main()即主函数!!!C横须的入口,即所有的c程序都是从main()开始执行!!!
    char \*argv[]记录参数
    int argc:参数的个数
    return 0返回,或函数结束。

  • 数据类型
    字符型(char):由’‘引起来的单个字母,数字或其他符号例如 ’e‘ 'l' 'i'等都是字符。
    getchar():获取单个字符,
    putchar():输出单个字符,
    实型/浮点型(float double):float单精度,有效位7位左右 ,double/双精度有效位15位左右。
    构造数据的类型,数据类型,结构体(struct),联合体(union)
    指针类型,空类型/void

  • sizeof()计算数据类型或者变量所在内存空间的大小,字节数。

sizeof()                    DateType
sizeof(char)                    1
sizeof(short)                   2
sizeof(int)                     4
sizeof(float)                   4
sizeof(long)                    8
sizeof(double)                  8
  • 逗号表达式:
    表达式1,表达式2,表达式3,...;
    表达式会依次执行,但是逗号表达式的值以最后一个表达式为准。
#include
int main(int argc,char *argv[]){
    int a = 3;
    a + 2,a*3,a-5;
    printf("a = %d\n",a);//3
    printf("%d\n",(a+2,a*3,a-5));//-2
    printf("%d\n",((a = a+4),(a*2,a/3)));//2
    return 0;
}
  • i++和++I的细节(代码示例):
#include
int main(){
    int num = 5;
    int sum1 = ++num + num++;//13
    num = 5;
    int sum2 = num++ + num++;//11
    num = 5;
    int sum3 = num++ + ++num;//12
    num = 5;
    int sum4 = ++num + ++num;//14
    printf("%d\t%d\t%d\t%d\n",sum1,sum2,sum3,sum4);
    return 0;
}

C高级的预习

  • 1,指针函数
    返回类型标识符 *返回名称(形式参数表){函数体}
    (每一个函数,他自身都有一个入口地址,该地址相当于一个指针。返回值相当于返回了一个指针变量的值,不过这是的“变量”时函数本身
#include
float *find();
int main(int argc,char **argv[])
{
    static float score[][4] = {{60,70,80,90},{56,89,34,45},{34,23,56,45}};
    float *p;
    int i,m;
    printf("Enter the number to be found:");
    scanf("%d",&m);
    printf("the score of NO.%d are:\n",m);
    p = find(score,m);
    for(i = 0;i < 4;i++)
        printf("%5.2f\t",*(p+i));
}
float *find(float (*pionter)[4],int n){
    float *pt;
    pt = *(pionter+n);
    return (pt);
}

自己将函数重新默写了一遍,在书上查找不懂得地方,大大加深了自己对指针的理解,以及指针函数的认识。

  • 2,函数指针
    数据类型标识符 (*指针变量名) (参数)
    指向函数的指针变量,和指针变量指向其他数据类型类似,此处指向函数的入口地址
#include
int max(int x,int y){
    return (x>y?x:y);
}
void main(int argc,char *argv[]){
    int (*ptr)();
    int a,b,c;
    ptr = max;
    scanf("%d,%d",&a,&b);
    c = (*ptr)(a,b);
    printf("a=%d,b=%d,max=%d",a,b,c);
}

此处ptr指向max函数的入口地址,运行时和max函数无任何区别,函数指针可以随意指向任何一个函数,而不像函数那样名称被固定了,但函数指针没有++和--

  • 3,函数指针的用法:
    1)定义函数指针变量:
    typedef int (*PTRFUN) (int aPara);
    2)函数指针变量的定义:
int (*pFun2) (int a);```
3)函数指针作为函数的参数传递:

typedef int (PTRFUN) (int aPara);
int CallBack(int a){
return ++a;
}
void Caller(PTRFUN cb)
//void Caller(int (
cb) (int))//也可以这样声明
{
int nPara = 1;
int nRet = cb( nPara);
}
//使用回调
void Test(){
Caller(CallBack);//直接调用回调函数
PTRFUN cb = CallBack;//int (*cb)(int);cb = CallBack;
int nRet1 = cb(99);//nRet1 = 100;
}```
使用函数指针的方法,在再一次的对用函数,(回调函数)
4)函数指针数组的使用

PTRFUN fArray[10];
//int (*fArray[10] (int));
for(int i = 0;i < 10;i++){
fArray[i] = CallBack;
int nRet = fArray[i](i);
}

5)函数指针的大小
int nSz1 = sizeof(PTRFUN);//nSz1 = 4;

数组于动态申请

malloc和free应该成对出现,否则容易出现系统崩溃,代码编写应该采用谁申请,就由谁调用比如:

char *p = malloc(...);
if(p==NULL)
...;
function(p);
...
free(p);
p=NULL;
直接定义函数对p进行操作。
void founction(char *p)
{
/*对p的一系列操作*/
}

void指针和空指针

  • 空指针是NULL,NULL是在中定义的一个宏。(不能间接引用一个空指针).

1)空指针终止对递归数据结构的间接引用

#include
unsigned factorial(unsigned i);
int main(int argc,char *argv[]){
    unsigned i;
    printf("input i:\n");
    scanf("%u",&i);
    int a = factorial(i);
    //int a = 5;
    printf("%d\n",a);
    return 0;
}
unsigned factorial(unsigned i){
    if(i == 0||i == 1){
        return 1;
    }else{
        return i * factorial(i-1);
    }
}

常见的递归数据结构是(单向)链表,链表中的每一个元素和一个指向链表中下一个元素的指针。可以通过指向第一个元素的指针开始引用一个链表,每一个元素指向下一个链表;当是指向最后一个元素的指针被赋值为NULL;就可以终止对链表的引用了。

while(p! = NULL){
/*d0 something with p-->str*/
p=p-->next;
}

2)用空指针作函数调用失败时的返回值

(。。。明天继续更新)

作业

1,熟悉并掌握printf()和scanf()的用法,及scanf()函数易碰到的问题
2,掌握几种基本数据类型及使用方法
3,使用算术运算符进行简单的四则运算及混合运算
4,逗号表达式的使用
5,预习逻辑运算符,位操作运算符,分支结构和循环结构
(全部已完成)

你可能感兴趣的:(C高级预习(6)和C语言基础(1))