【C】无类型指针及函数指针

news/2024/11/8 4:18:06 标签: c语言, 开发语言, 指针, 笔记

一、无类型指针

(1)无类指针只包含内存地址,不知道内存地址从存放数据是什么类型:
        void *ptr=NULL;

(2)可以其他类型赋给无类型指针,但是无类型指针赋给有类型指针会警号;
        不可通过*ptr获取里里面的内容,如要赋值必须强制转化
         p_ch=(char *)ptr;//这样比较好

(3)void* 通常用在函数的参数中,给函数参数带来很大的灵活性,当函数参数是void*,可以接受任意数据地址,但无法判断是什么类型,可以加个类型判断
void test(void *data,int type)
{
    if(type==1)
    {
        printf("%c\n",*((char*)data));//字符型
    }
    else if(type==2)
    {
        printf("%d\n",*((int *)data));//整型
    }
    else if(type==3)
    {
        printf("%d\n",((STU*)data)->age);//结构体型
    }
}


二、指针数组

1.定义一个数组,专门存放整形指针,相当于一维数组
 int *p[5];

char  (*pmenu)[10],menu[5][10]=
{"aaa","bbbb","ccc",”dd","ee"};
pmenu=menu;
for (i = 0;i < 5;i++){
    puts(pmenu[i]);
}

  

2.定义指针,专门指向包含5个元素的一维指针数组,像当于二维数组    
int (*p_array)[5]=p;

char  *pmenu[5],menu[5][10]=
{"aaa","bbbb","ccc",”dd","ee"};
for (i = 0;i < 5;i++)
    pmenu[i] = menu[i];
for (i = 0;i < 5;i++)
    puts(pmenu[i]);

3.函数指针(常用)
    (1)定义:
                函数指针,一个指针专门指向函数地址
                p_fun定义一个函数指针,指向int有返回值,并且参数就一个整数函数
                int (*p_fun)(int )=NULL;
    (2)赋值:
                把getMax函数地址赋给p_fun;
                p_fun=test;
    (3)调用这个函数:
              getMax(10);//方法1
              p_fun(1200);//方法2

4.函数指针,定义一个数组,定义一个数组,里面每个元素存放一个函数指针
    //这里面存放5个
    int (*p_funArray[5])(int)={getMax,test,pos_win,reg_win,manager_win};
    b=p_funArray[2](a);

函数指针的例子:

#include<stdio.h>


int getMax(int a)
{
//	printf("%d\n",a);
	printf("getMax!\n");
	
	return a+1;
}
int test(int parm)
{
	printf("hello,world!\n");
//	printf("%d\n",parm);
	return parm+1;
}
int pos_win(int max)
{
	printf("pos_win!\n");
	return max+1;
}
int reg_win(int max)
{
	printf("reg_win!\n");
	return max+1;
}
int manager_win(int max)
{
	printf("manager_win!\n");
	return max+1;
}

int main()
{
	int a=0,b=0,c=0;

	//定义一个数组,里面每个元素存放一个函数指针
	//这里面存放5个
	int (*p_funArray[5])(int)={getMax,test,pos_win,reg_win,manager_win};

	while(1)
	{
		b++;
		c=p_funArray[b]();
		printf("b=%d\n",b);
	//	getch();
	

	}

}

 


http://www.niftyadmin.cn/n/5743218.html

相关文章

详解Rust标准库:VecDeque 队列

theme: github highlight: an-old-hope 查看本地官方文档 安装rust后运行 rustup doc查看The Standard Library即可获取标准库内容 std::connections::VecDeque定义 队列是遵循先入先出规则的线性数据结构&#xff0c;在内存中不一定连续 VecDeque定义&#xff1a;可增长…

K8S群集调度二

一、污点(Taint) 和 容忍(Tolerations) 1.1、污点(Taint) 设置在node上是对pod的一种作用 节点的亲和性&#xff0c;是Pod的一种属性&#xff08;偏好或硬性要求&#xff09;&#xff0c;它使Pod被吸引到一类特定的节点 而Taint 则相反&#xff0c;它使节点能够排斥一类特…

如何编译安装LNMP环境

LNMP 是 Linux、Nginx、MySQL 和 PHP 的组合&#xff0c;是一种流行的 Web 服务环境。以下是如何在一个典型的 Linux 系统&#xff08;如 Ubuntu 或 CentOS&#xff09;上编译安装 LNMP 环境的详细步骤&#xff1a; 1. 准备工作 确保你的系统是最新的&#xff0c;并安装一些必…

驱动-----中断底半部

之前处理中断在中断服务程序里面&#xff0c;就是我们自己注册了一个中断服务程序&#xff0c;一产生中断就自动调动这个程序。 但是中断的处理越快越好 同步调用&#xff1a;就是等调用的函数执行完毕然后再返回原来的位置。 异步调用&#xff1a;就是不等调用的函数执行完…

线性数据结构之栈结构

栈&#xff08;Stack&#xff09;是一种线性数据结构&#xff0c;遵循“后进先出”&#xff08;Last In, First Out&#xff0c;LIFO&#xff09;的原则。栈主要有两种基本操作&#xff1a;push&#xff08;入栈&#xff09;和 pop&#xff08;出栈&#xff09;。在栈中&#x…

linux驱动-i2c子系统框架学习(1)

可以将整个 I2C 子系统用下面的框图来描述&#xff1a; 可以将上面这一 I2C 子系统划分为三个层次&#xff0c;分别为用户空间、内核空间和硬件层&#xff0c;内核空间就包括 I2C 设备驱动层、I2C 核心层和 I2C 适配器驱动层&#xff0c; 本篇主要内容就是介绍 I2C 子系统框架中…

Linux,shell基础,变量,数值运算

linux 一.shell基础1.什么是shell在linux内核与用户之间的解释器程序,通常指/bin/bash2.shell的使用方式1.交互式2.非交互式3.Bash基本特征1.快捷键2.历史命令3.重定向4.管道5.别名4.shell脚本1.规范脚本构成(1) #!指定解释器(2) # 注释信息(作者信息,步骤,思路,用途,变量等)(3…

i2c-tools 4.3 for Android 9.0

i2c-tools 4.3 Android 9.0下编译i2c-tools 4.3 下载源码 cd external wget https://mirrors.edge.kernel.org/pub/software/utils/i2c-tools/i2c-tools-4.3.tar.gz tar -zxvf i2c-tools-4.3.tar.gz 增加Android.mk Android.mk LOCAL_PATH : $(call my-dir)include $(C…