/*函数指针*/ #include<stdio.h> void PrintMin(int a, int b) { if (a < b) printf("%d ", a); else printf("%d ", b); } int main() { void(*pf)(int, int); int x = 6, y = 5; //PrintMin(x, y); pf = PrintMin; pf(x, y); //while (1); system("PAUSE"); return 0; } //void qsort(void *base, int nelem, unsigned int width, // int(*pfCompare)(const void *, const void *)); //是 void * 类型 //int 比较函数名(const void * elem1, const void * elem2); //比较函数编写规则: //1) 如果 * elem1应该排在 * elem2前面,则函数返回值是负整数 //2) 如果 * elem1和* elem2哪个排在前面都行,那么函数返回0 //3) 如果 * elem1应该排在 * elem2后面,则函数返回值是正整数 #include <stdio.h> #include<stdlib.h> int MyCompare(const void* elem1, const void* elem2) { unsigned int *p1, *p2; p1 = (unsigned int*)elem1; // *elem1 非法,因为不知道数据类型 p2 = (unsigned int*)elem2; //return (*p1 % 10) - (*p2 % 10) ; return (*p2 % 10) - (*p1 % 10); //return 0; } #define NUM 5 int main() { unsigned int an[NUM] = { 8,123,11,10,4 }; qsort(an, NUM, sizeof(unsigned int), MyCompare); for (int i = 0; i < NUM; i++) printf("%d ", an[i]); while (1); return 0; }
/*引用*/ #include<iostream> using namespace std; int n = 4; int & SetValue() { return n; } int main() { n = 10; SetValue()=40; cout << n; return 0; }