Linux C 程序 指针数组和二级指针(TEN)
指针数组和二级指针
#include<stdio.h>
int main(){
] = {,,,,};
], i;
int **pp = p;
//使p指针数组指向每一个a
; i < ; i++){
p[i] =&a[i];
}
//【】优先级高于* ,*(p[i]) p[i] = &a[i],so==> *p[i] = *&a[i] = a[i]
; i < ; i++){
printf("%d ",*p[i]);
}
printf("\n");
//p 和 pp都是二级指针,i=0时,*pp=p[0] ,p[0]=&a[i],*pp=a[0].
//执行pp++之后,pp指向p[1],*pp=p[1],p[1]=&a[1].
; i < ; i++,pp++){
printf("%d ",**pp);
}
;
}
output:
指针与数组的 关系
nclude<stdio.h>
int main(){
][] = {,,,,,,,,,};
//表示p是一个指针,指向含有五个元素的一维数组
],i;
//p指向二维数组得第一行
p = a ;
//p=a 之后 , p=&a , *p = a[1].
//p是一个数组指针
; i < ; i++){
printf("%d ",(*p)[i]);
//(*p)[i] 是先取p的内容作为数组的起始地址,然后再去第i个元素。
//*p[i]是先取以p为起始地址的第i个元素,该元素为指针,然后取该指针的内容。
}
printf("\n");
//p移动到第二行
p++;
; i < ; i++){
printf("%d ",(*p)[i]);
}
printf("\n");
;
}
] ;//一个指针
] ; //含有五个元素的数组,长度为5,数组中得每一个元素指向一个整型变量。
函数和指针
1.指针作为函数得参数
作用是将一个变量的地址传送到一个函数中
#include<stdio.h>
void change(int i , int *p){
i++;
if(p != NULL){
(*p)++;//根据地址找到变量b,b+1
}
}
int main(){
, b = ;
change(a,&b);
printf("a=%d,b=%d",a,b);
;
}
2.返回指针得函数
int *f(int i , int j);
() 的优先级高于 *
表示 f是一个函数,函数名前有一个指针,表示此函数得返回值类型为指针。
include<stdio.h>
//定义一个名称为name得指针数组,每个数组元素都指向一个字符串
] = {"monday","tuesday","wednessday","thursday","friday","saturday","sunday"};
//定义一个指针,这个指针指向一个字符串
char *message = "wrong input";
//返回指针的函数
char *week(int day){
|| day > ){
return message ;
}else{
] ;
}
}
int main(){
int day ;
char *p;
printf("input a number of a week:\n");
scanf("%d",&day);
p = week(day);
printf("%s\n",p);
;
}
3.指向函数的指针:
#include<stdio.h>
#define GET_MAX 0
#define GET_MIN 1
int get_max(int i , int j){
return i > j ? i : j ;
}
int get_min(int i , int j){
return i < j ? i : j ;
}
int compare(int i , int j , int flag){
int ret ;
//声明指向函数的指针
int (*p)(int ,int);
if(flag == GET_MAX){
p = get_max;//函数名
}else{
p = get_min;
}
ret = p(i , j );
return ret ;
}
int main(){
, j = , ret ;
ret = compare(i , j , GET_MAX);
printf("max = %d\n",ret);
ret = compare(i, j , GET_MIN);
printf("min = %d\n",ret);
}
不能对指向函数的指针做任何运算。
int *f(int i , int j);//返回指针的函数 int (*p)(int i , int j);//指向函数的指针
4.函数指针做形参
函数的参数可以是指针,淡然也可以是指向函数的指针
int get_max(int i , int j,int k , (*p)(int ,int));
该函数接收4个参数,函数内通过指针调用其他函数,信号处理会使用这种技术。
eg:
#include<stdio.h>
int get_big(int i , int j){
return i > j ? i : j ;
}
//get_max函数里有个指向函数的指针做参数
int get_max(int i ,int j ,int k ,int (*p)(int ,int)){
int ret ;
ret = p(i , j );
ret = p(ret , k);
return ret ;
}
int main(){
, j = , k = , ret ;
ret = get_max(i , j , k , get_big);
printf("max = %d",ret);
;
}
5.返回函数指针的函数
eg:
#include<stdio.h>
int get_big(int i , int j){
return i > j ? i : j ;
}
//()优先级高于* , get_function先和()结合,成为一个函数,他的返回值是一个指向函数的指针 int (*)(int ,int)
int (*get_function(int a))(int ,int ){
printf("the number is %d",a);
return get_big;
}
int main(){
, j = , max ;
int (*p)(int ,int);
p = get_function();
max = p(i , j );
printf("max number is %d",max);
;
}
数组名始终指向该数组的第一个元素,不允许做a++运算,新申明的指针则可以随意移动
Linux C 程序 指针数组和二级指针(TEN)的更多相关文章
- C++指针数组,二级指针和函数指针的练习
1.编一程序,将字符串“Hello,C++!”赋给一个字符数组, 然后从第一个字母开始间隔地输出该串(请用指针完成). 代码如下 #include<iostream> #include&l ...
- C/C++——二维数组与指针、指针数组、数组指针(行指针)、二级指针的用法
本文转载自:https://blog.csdn.net/qq_33573235/article/details/79530792 1. 二维数组和指针 要用指针处理二维数组,首先要解决从存储的角度对二 ...
- C++中的指针、数组指针与指针数组、函数指针与指针函数
C++中的指针.数组指针与指针数组.函数指针与指针函数 本文从刚開始学习的人的角度,深入浅出地具体解释什么是指针.怎样使用指针.怎样定义指针.怎样定义数组指针和函数指针.并给出相应的实例演示.接着,差 ...
- 《挑战30天C++入门极限》C/C++中字符指针数组及指向指针的指针的含义
C/C++中字符指针数组及指向指针的指针的含义 就指向指针的指针,很早以前在说指针的时候说过,但后来发现很多人还是比较难以理解,这一次我们再次仔细说一说指向指针的指针. 先看下面的代码,注意看 ...
- OpenCV二维Mat数组(二级指针)在CUDA中的使用
CUDA用于并行计算非常方便,但是GPU与CPU之间的交互,比如传递参数等相对麻烦一些.在写CUDA核函数的时候形参往往会有很多个,动辄达到10-20个,如果能够在CPU中提前把数据组织好,比如使用二 ...
- C语言复习---二维数组和二级指针的关系:没关系,别瞎想(重点)
前提:一维数组和一维指针为什么可以替换使用? ] = { , , }; int *p = a; ; i < ; i++) printf("%d ", *(p + i)); 上 ...
- 二维数组是二级指针pointer to pointer!
二维数组居然是个类似于二级指针(pointer to pointer)的东西,十分震惊! #include <stdio.h> int main() { ][]={{,,,},{,,,}, ...
- C++指针数组和指向指针的指针
指针数组 定义: 如果一个 数组,其元素均为指针型数据,该数组为指针数组,也就是说,指针数组中的每一个元素相当于一个指针变量,它的值都是地址. 形式: 一维指针数组的定义形式为: int[类型名] * ...
- C++数组指针、指针数组、函数指针的核心概念
1.什么叫数组指针? 数组指针:一个指向一维或者多维数组的指针. 比如:int * b=new int[10];指向一维数组的指针b ; 注意,这个时候释放空间一定要delete [] ,否则会造成内 ...
随机推荐
- MySQL · 特性分析 · innodb 锁分裂继承与迁移
http://mysql.taobao.org/monthly/2016/06/01/ innodb行锁简介 行锁类型 LOCK_S:共享锁 LOCK_X: 排他锁 GAP类型 LOCK_GAP:只锁 ...
- php上传常见文件类型对应的$_FILES["file"]["type"](转)
php上传常见文件类型对应的$_FILES["file"]["type"] from:http://hi.baidu.com/7book/item/374971 ...
- iCloud之旅
1.创建BIDTinyPixDocument类 #import <UIKit/UIKit.h> //创建文档类 @interface TinyPixDocument : UIDocumen ...
- JAVAMAIL手动发送邮件
telnet smtp.sina.com 25ehlo hncu/*ehlo命令是SMTP邮件发送程序与SMTP邮件接收程序建立连接后必须发送的第一条SMTP命令,参数<domain>表示 ...
- mysql颠覆实战笔记(七)--白话理解事务
今天我们学习web开发级mysql颠覆实战课程第9课没MYSQL事务(一):白话理解事务.前面有两节课第7讲:商品系统设计(四):商品属性设计之自定义属性,第8讲:商品系统设计(五):一维属性的商品价 ...
- 为Mono安装MySql连接驱动
为Mono安装MySql连接驱动(转) 2013 年 1 月 24 日.NETmono.MySql DOTNET and Mono by default only support database c ...
- SRM 584 第一次玩TopCoder。。。只水题一道。。。
第一次topcoder,以前老感觉没有资格去做tc,cf什么的,现在已经慢慢接触了. 感觉还可以,还是有让我们这些蒻菜安慰的水题. tc的确很好玩,用客户端比赛,还有各种规则,而且还是只编写一个类提交 ...
- South——谁说Django不能migrate!
零.前言 最近改一个项目,需要对已有的model进行更改.大家都知道Django自带的syncdb只能创建数据库,但是无法将已经改变的model应用的数据库中. 大概两年前遇到这个问题的时候,网上的答 ...
- hdu 4585 set应用
#include<iostream> #include<algorithm> #include<cstring> #include<cstdio> #i ...
- 高效的网络流dinic算法模版
#include <cstring> #include <algorithm> #include <vector> #define Maxn 120010 #def ...