当前位置: 首页 > web >正文

Linux学习--C语言(指针3)

1.指针函数和函数指针

1.1 指针函数

指针函数是函数,函数的返回值是指针

  • 不能返回局部变量的地址
  • 指针函数返回的地址可以作为下一个函数调用的参数

 1.2 函数指针

函数指针是指针,指针指向一个函数

#include <stdio.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 jisuanqi(int x, int y, int (*p)(int x, int y))
{return p(x,y);
}int main(void)
{int (*p)(int x, int y) = NULL;int num1 = 0;int num2 = 0;char op = 0;scanf("%d %c%d",&num1,&op,&num2);switch(op){case '+':p = Add;break;case '-':p = Sub;break;case '*':p = Mul;break;case '/':p = Div;break;}printf("Ret = %d\n",jisuanqi(num1, num2, p));    //p指向某函数return 0;
}

2.二级指针

2.1 定义

二级指针是指向一级指针变量的指针

int **q;定义一个指针变量q,占8个字节空间,指向ige指针变量空间,即指向一级指针变量的指针

2.2 使用场景

1.函数体内部想修改函数体外部指针变量的值时,需要传递指针变量的地址即二级指针

2.指针数组传参,数组的数组名是指向数组第一个元素的指针,第一个元素是指针,所以数组名为指向指针的指针即二级指针

3.指针数组和数组指针

3.1 定义

1.指针数组:是数组,数组的每个元素是指针

2.数组指针:是指针,指针指向整个数组

int *a[5];
定义一个数组,占40个字节空间,数组名为a,每个元素都是int *型的指针int (*a)[5];
定义一个指针,占8个字节,指针变量名为a,是指向数组为20个字节空间的指针

3.2 指针数组

int *a[5];
char *pstr[5];
  • 存放字符串使用字符型数组,操作字符串使用指针
  • 存放字符串数组使用字符型二维数组,操作字符串数组使用指针数组

3.3 利用指针数组操作二维数组中的字符串实现排序

  • 二维数组存放字符串数组
  • 指针数组元素变化代替二维数组字符串变化,提高程序效率

 

3.4 数组指针

  • 对一维数组数组名&:值不变 ,类型升级为指向整个数组的指针
  • 对指针数组*:值不变,类型降级为指向数组第一个元素的指针
int a[5] = {1,2,3,4,5};a == &a[0];a == int *

注意:两种情况a不能理解为int *

  • sizeof:获得数据类型、变量所占字节
  • &:&int * -> int **   &a -> int (*p)[5]

 第十一行:&a+1指向下一个数组的首地址,再强制转换为int *型,再减一即减去四个字节,回到数组a的第五个元素,故打印出来为5

 3.5 数组指针的使用场景

 1.一维数组和指针的关系

  • 数组的数组名是指向数组第一个元素的指针常量
int a[5] = {1,2,3,4,5};
int *p = NULL;p = &a[0];
p = a;a == &a[0];a[n] == *(a+n) == *(p+n) == p[n]

2.二维数组和指针的关系

  • 数组的数组名是指向数组第一行的数组指针
int a[2][3] = {1,2,3,4,5,6};
int *p = NULL;
int (*q)[3] = NULL;p = &a[0][0];
p = a[0];
p = *a;
q = a;a:指向数组第一行元素的数组指针    int (*)[3]
a[0]:指向a[0][0]的指针           int *
a[1]:指向a[1][0]的指针           int *访问数组第m行第n列元素的方式:
a[m][n]
*(a[m]+n)
*(*(a+m)+n)
*(p+m*N+n)
*(*(q+m)+n)
*(q[m]+n)
q[m][n]

作业

1.封装一个函数,将字符串“12345”转换成整形12345

2.封装函数实现mystrlen,mystrcpy,mystrcat,mystrcmp功能

3.从终端接收五个字符串,对他们排序后输出

#include <stdio.h>int ToNum(char *a)
{int i = 0;int num[32] = {0};int sum = 0;while(*a != '\0'){num[i] = *a - '0';sum = sum * 10 + num[i];i++;a++;}return sum;
}int main(void)
{char a[32] = "12345";printf("outnum = %d\n",ToNum(a));return 0;
}
#include <stdio.h>int mystrlen(const char *str)
{int i = 0;while(*str != '\0'){str++;i++;}return i;
}char *mystrcpy(const char *pstr, char *pret)
{char *ret = pret;while(*pstr != '\0'){*pret = *pstr;pret++;pstr++;}return ret;
}int mystrcmp(const char *pstr, const char *pdst)
{while(*pstr == *pdst){if(*pstr == '\0'){return 0;}pstr++;pdst++;}return *pstr - *pdst;
}char *mystrcat(char *pstr, const char *pdst)
{int len = mystrlen(pstr);char *str = pstr;pstr += len;while(*pdst != '\0'){*pstr = *pdst;pstr++;pdst++;}return str;
}int main(void)
{char str[100] = {0};char dst[100] = {0};char ret[100] = {0};gets(str);gets(dst);printf("strlen:len_str = %d\n",mystrlen(str));printf("strcpy:ret_cpy_str = %s\n",mystrcpy(str,ret));if(mystrcmp(str,dst) > 0){printf("str > cmp\n");}else if(mystrcmp(str,dst) == 0){printf("str = dst\n");}else{printf("str < dst\n");}printf("strcat:new_str = %s\n",mystrcat(str,dst));return 0;
}
#include <stdio.h>
#include <string.h>int main(void)
{char a[5][100] = {0};char *pstr[5] = {a[0], a[1], a[2], a[3], a[4]};char tmp[100] = {0};int i = 0;int j = 0;for(i = 0; i < 5; i++){gets(a[i]);}for(j = 0; j < 4; j++){for(i = 0; i < 4-j; i++){if(strcmp(pstr[i], pstr[i+1]) > 0){strcpy(tmp,pstr[i]);strcpy(pstr[i], pstr[i+1]);strcpy(pstr[i+1], tmp);}}}for(i = 0; i < 5; i++){printf("a[%d] = %s\n",i,a[i]);}return 0;
}

http://www.xdnf.cn/news/16607.html

相关文章:

  • tsc命令深入全面讲解
  • 【Linux】编辑器vim和编译器gcc/g++
  • 【计算机网络】计算机网络中光猫、交换机、路由器、网关、MAC地址是什么?两台电脑是如何联通的?
  • leetcode 2044. 统计按位或能得到最大值的子集数目 中等
  • 自定义View学习记录 plinko游戏View
  • 【OS】真题 2015
  • 架构实战——互联网架构模板(“开发层”和“服务层”技术)
  • JavaWeb 入门:HTML 基础与实战详解(Java 开发者视角)
  • python对象的__dict__属性详解
  • 5G MBS(组播广播服务)深度解析:从标准架构到商用实践
  • Linux 题目总结参考
  • 低速信号设计之 SMBUS 篇
  • 零基础学习性能测试第六章:性能难点-Jmeter文件上传场景压测
  • 网络虚拟化:veth,bridge,network namespace与docker网络
  • Word和WPS文字如何制作分栏试卷?想分几栏分几栏
  • Java面试实战:安全框架与大数据技术深度解析
  • 【模电笔记】—— 波形发生电路(波形振荡器)
  • ArKTS:List 数组
  • 每日算法刷题Day55:7.27:leetcode 复习完第K小/大+栈4道题,用时1h50min
  • Python初学OpenCV:图像预处理进阶指南(二)
  • 数据结构 堆(4)---TOP-K问题
  • Android Framework知识点
  • Linux文件理解,基础IO理解
  • 「mysql」Mac osx彻底删除mysql
  • 数据赋能(340)——技术平台——共享平台
  • Process Monitor学习
  • C语言——关于指针(逐渐清晰版)
  • 2.安装CUDA详细步骤(含安装截图)
  • Spring 容器注入时查找 Bean 的完整规则
  • 动手学深度学习笔记04(上)