C语言指针5

1.去掉函数名和形参,剩下的就是函数的返回类型

2.函数的返回类型如果是函数指针的话,那就说明他返回的是一个函数的地址

3.

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>

typedef void(*p)(int);
int main()
{
	void(*func11(int, void(*)(int)))(int);
	//上述代码等价于
	p func11(int, p);
	return 0;
}

4.switch语句当中的break是跳出当前的switch语句,记得可以有个default语句

5.转移表的另一个麻烦写法:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>

int Add(int x, int y)
{
	return x + y;
}

int Sub(int x, int y)
{
	return x - y;
}

int Mul(int x, int y)
{
	return x * y;
}

int Div(int x, int y)
{
	return x / y;
}

int main()
{
	int input = 0;
	printf("input的值\n");
	scanf("%d", &input);
	printf("操作数");
	int x, y;
	scanf("%d %d", &x, &y);
	while (input)
	{
		switch (input)
		{
		case 1:
			printf("%d\n", Add(x, y));
			break;			
		case 2:
			printf("%d\n", Sub(x, y));
			break;
		case 3:
			printf("%d\n", Mul(x, y));
			break;
		case 4:
			printf("%d\n", Div(x, y));
			break;
		}
		printf("input的值\n");
		scanf("%d", &input);
		printf("操作数");
		scanf("%d %d", &x, &y);
	}

}




6.回调函数就是一个通过函数指针调用的函数.
如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,被调用的函数就是回调函数.回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应.

7.int* p = 0;

等同于

int* p = NULL;

8.

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );

qsort()函数第一个参数是 指向要排序的东西的首元素地址

第二个参数是 待排序的东西的个数

第三个参数是 待排序的东西的单个元素的大小

第四个参数是函数指针, 这个函数是用来比较待排序的东西的两个元素的,比较elem1和elem2指向的元素,如果elem1 < elem2,则要求返回一个小于0的数字;如果elem1 == elem2,则要求返回一个等于0的数字;如果elem1 > elem2,则要求返回一个大于0的数字.所以那个函数指针指向的函数的参数必须是(const void *elem1, const void *elem2 ) ,返回类型必须是int.而要对两个元素进行比较的话,只需强制类型转换即可.

默认是调成升序.

9.qsort()函数使用例子复习搜

10."\0"和'\0'不一样.

双引号引起来的是字符数组,类型是char[ ],后面还隐藏一个\0,单引号的是一个字符,类型是char

前者有两个\0

11.使用qsort函数来排列结构体数据例子

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

struct stu
{
	char name[20];
	int age;
	int score;
};

int com_age(const void* elem1, const void* elem2)
{
	struct stu* p1 = (struct stu*)elem1;
	struct stu* p2 = (struct stu*)elem2;
	return p1->age - p2->age;
}

int com_score(const void* elem1, const void* elem2)
{
	struct stu* p1 = (struct stu*)elem1;
	struct stu* p2 = (struct stu*)elem2;
	return p1->score - p2->score;
}

int com_name(const void* elem1, const void* elem2)
{
	struct stu* p1 = (struct stu*)elem1;
	struct stu* p2 = (struct stu*)elem2;
	return strcmp(p1->name, p2->name);
}

int main()
{
	struct stu a1 = { "zhangsan",18,60 };
	struct stu a2 = { "lisi",28,98 };
	struct stu a3 = { "wangwu",25,92 };
	struct stu arr[] = { a1,a2,a3 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	//qsort(arr, sz, sizeof(arr[0]), com_age);//按照年龄
	//qsort(arr, sz, sizeof(arr[0]), com_score);//按照成绩
	//qsort(arr, sz, sizeof(arr[0]), com_name);//按照名字
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d %d\n", arr[i].name, arr[i].age, arr[i].score);
	}

	return 0;
 }

12.strcmp是按照对应位置的ASCILL码值来比较大小的

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值