20150423函数指针

Posted wzg31796

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了20150423函数指针相关的知识,希望对你有一定的参考价值。

一.二维数组

1.在栈上创建数组

一维数组:int *p=(int [])0;

二维数组:int (*px)[4]=(int [][4])0;

三维数组:int (*py)[3][4]=(int [][3][4])0;


2.堆上分配二维数组(地址不连续)

void    main2()

	int **pp = calloc(3, 4);//分配指针数组
	for (int i = 0; i < 3;i++)
	
		pp[i] = malloc(4 * sizeof(int));//每个指针分配内存
	
	int num = 0;
	for (int i = 0; i < 3;i++)
	
		for (int j = 0; j < 4;j++)
		
			printf("%4d",pp[i][j]=num++ );// *( *(pp+i)+j)  pp[i][j]
			//*(pp+i)  ==pp[i]   pp+i  == &pp[i]
 		
		printf("\\n");
	
	for (int i = 0; i < 3;i++)//先释放块
	
		free(pp[i]);
	
	free( pp);//再释放指针数组

	system("pause");

3.堆上分配二维数组(地址连续)

void main4()

	int(*p)[4] = malloc(sizeof(int)* 12);//连续

	int num = 0;
	for (int i = 0; i < 3; i++)
	
		for (int j = 0; j < 4; j++)
		
			printf("%4d", p[i][j] = num++);//
		
		printf("\\n");
	
	free(p);

	system("pause");


二.函数指针

1.函数指针的非法调用

不可以在一个进程中调用另一个进程的函数,但可以用dll函数调用另一个进程的函数,实现非法调用

<span style="font-size:24px;">_declspec(dllexport)  void main()

	void (*p)()=0x10510b9;//函数指针,地址为要调用函数的地址
	p();//调用


</span>

2.函数指针变量,在数据区,但是存储了代码区的地址,函数在代码区


四.函数指针强化

1.函数指针用法

int add(int a, int b)

	return a + b;


int sub(int a, int b)

	return a - b;

int mul(int a, int b)

	return a * b;

int divv(int a, int b)

	return a /b;


int  getmax(int a, int b)

	return a > b ? a : b;


int  getmin(int a, int b)

	return a < b ? a : b;

void op(  int (*p)(int,int)  ,int a,int b  )

	printf("%d\\n", p(a, b));



void main2()

	op(add, 1, 2);

	op(divv, 1, 2);


	system("pause");

2.返回函数时的用法

void main1()

	int(*p1)(int a, int b)=add(1,2);
	int(*p2)(int, int)=add;//参数名可以省略
	p1(1, 2);
	//p1++;  函数指针没有自增,自建
	//p2++;
	//p3 + n;


//int(*p)(int, int)函数指针
//int(*)(int, int) 函数指针类型
//int(* get() )(int, int)  //一个函数,参数为空,返回值是一个函数指针
//

//   int(    * get(int (*y)(int,int),double)         )(int, int) 
// int(    *         )(int, int) //函数指针类型
//  get(  int (*y)(int,int)   ,    double)   整体

int(* getop())(int, int)

	return add;





void main()

	printf("%d", getop()(1, 2));

	system("pause");




五.函数指针数组与二级函数指针

1.动态函数指针用法

void main3()

	int(**pp)(int, int) = malloc(sizeof(int(*)(int, int)) * 4);//堆区
	*pp = add;
	*(pp + 1) = sub;
	*(pp + 2) = mul;
	*(pp + 3) = divv;

	for (int i = 0; i < 4; i++)
	
		//	printf("%d\\n", pp[i](100, 10));
		printf("%d\\n", (*(pp + i))(100, 10));
	


	system("pause");


2.int (*p)[5];  指向数组的指针,占四个字节

int *p[5];是一个数组,每一个元素是一个指针


七.函数指针数组与多线程

1.多线程异步执行多个函数

void run1(void*p)

	MessageBoxA(0, "1", "1", 0);

void run2(void*p)

	MessageBoxA(0, "2", "2", 0);

void run3(void*p)

	MessageBoxA(0, "3", "3", 0);


void main()

	//run1(NULL);
	//run2(NULL);
	//run3(NULL);
	//for (int i = 0; i < 3;i++)
	//
	//    HANDLE hd=	_beginthread(run1, 0, NULL);
	//	//WaitForSingleObject(hd, INFINITE);//无限等待
	//	WaitForSingleObject(hd, 3000);//3000等待3秒
	//
	//HANDLE hd[3] =  0 ;
	HANDLE *hd = malloc(12);
	//void(*pfun[3])(void*p) =  run1, run2, run3 ;//函数指针数组
	void(**pfun)(void*p) = (void(*[3])(void*p)) run1, run2, run3 ;

	for (int i = 0; i < 3;i++)
	

		hd[i] = _beginthread(pfun[i], 0, NULL);
	
	//TRUE等待所有线程,fause等待一个
	WaitForMultipleObjects(3, hd, FALSE, INFINITE);//等待多个线程结束

	//

	//主线程,控制全局,

	//system("pause");

//线程可以同步,也可以异步
//WaitForSingleObject(hd, 3000);//3000等待3秒
//主线程,控制全局  
//WaitForMultipleObjects(3, hd, TRUE, INFINITE);//

八.栈内存分配

int *p=alloca(sizeof(int)* 10);

alloca分配内存后自动释放内存


十.函数返回值副本机制

1.函数返回指针的时候,不可以返回指针指向栈区的内存,要获取指针函数返回值,该函数必须在堆上开辟内存

int * rungetmin()

	int *p = calloc(10, sizeof(int));//不会自动释放
	time_t ts;
	unsigned int num = time(&ts);//地址改变数据
	srand(num);
	for (int i = 0; i < 10;i++)
	
		p[i] = rand() % 100;
		printf("\\n%d", p[i]);
	
	int imin = 0;//下标
	for (int i = 1; i < 10;i++)
	
		if (p[i]<p[imin])
		
			imin = i;//记录下标
		


	
	// p + imin   &p[imin]
	//*(p+imin)  p[imin]
	return p + imin;






void   main10()


	printf("最小的是%d", *rungetmin());

	system("pause");

2.普通在栈上的函数返回值有副本机制,存储在cpu,所以不能对其取地址等操作


以上是关于20150423函数指针的主要内容,如果未能解决你的问题,请参考以下文章

C++-------深拷贝

智能指针之atuo_ptr源码剖析

7.newdeleteOOPthis指针

求高手。讲解 malloc 函数的用法 在数据结构中多次出现,意思申请内存,可是不懂如何用

C语言动态开辟指针的指针问题

C语言进阶:动态内存管理