25深入理解C指针之---传递数组
一、传递数组:将数组作为参数传入函数,或将数组作为数据当成是函数的返回值
1、定义:可以传入和传出数组
2、特征:
1)、将数组作为参数传递给函数的本质是传递数组的地址,这种传递无需复制数组元素,所以更加高效;
2)、数组名自身暗中包含了数组的大小,传递过程中只包含地址,因而丢失了数组大小信息;
#include <stdio.h> void displayArr(int arr[]){
for(int i = ; i < ; i++){
printf("%d\t", arr[i]);
}
printf("\n"); return;
} int main(int argc, char **argv)
{
int arrInt[] = {, , , , , , , ,};
displayArr(arrInt); return ;
}
说明:由于在displayArr()函数中缺少了数组长度,由于盲目指定了数组长度,因此会输出多余的垃圾值。
3)、将数组作为参数时,可以使用数组表示法,arrName[]表示法;
#include <stdio.h> void displayArr(int arr[], int size){
for(int i = ; i < size; i++){
printf("%d\t", arr[i]);
}
printf("\n"); return;
} int main(int argc, char **argv)
{
int arrInt[] = {, , , , , , , ,};
int size = sizeof(arrInt) / sizeof(int);
displayArr(arrInt, size); return ;
}
说明:由于在displayArr()函数声明中使用数组表示法,传入了数组长度,在函数内部使用数组法(也可以使用指针法),保证了程序的健壮行。
4)、将数组作为参数时,可以使用指针表示法,*arrName表示法;
#include <stdio.h> void displayArr(int *arr, int size){
for(int i = ; i < size; i++){
printf("%d\t", *(arr + i));
}
printf("\n"); return;
} int main(int argc, char **argv)
{
int arrInt[] = {, , , , , , , ,};
int size = sizeof(arrInt) / sizeof(int);
displayArr(arrInt, size); return ;
}
说明:由于在displayArr()函数声明中使用指针表示法,传入了数组长度,在函数内部使用指针法(也可以使用数组法),保证了程序的健壮行。
5)、采用指针表示法和采用数组表示法必须传入数组的长度;
3、指针数组的应用:
1)、声明方式:int* arrName[size],此时数组中的元素是指针,若需要获取指针的内容,需要使用解析操作符;
2)、数组元素需要手动分配内存空间;
3)、使用数组表示法获取数组元素的内容:*arrName[index]获取指针内容;
4)、arrName[index] 等价于(*arrName + index),切记其中存储的是整型指针
5)、使用*arrName[index]获取数组下标对应的地址处的内容
6)、使用指针表示法获取数组元素的内容:*(*arrName + index)获取指针内容;
7)、(*arrName + index)等价于arrName[index],切记其中存储的是整型指针
8)、使用*(*arrName + index)获取指针运算后对应的地址处的内容
9)、如果不能确定具体的方式,就在初始化和输出使用同一种方式
10)、在代码2中如果在初始化时,使用第10行代码的形式,可以使用第15行代码输出数据
11)、在代码2中如果在初始化时,使用第10行代码的形式,可以使用第16行代码输出数据
12)、在代码2中如果在初始化时,使用第10行代码的形式,可以使用第18行代码输出数据
13)、在代码2中如果在初始化时,使用第11行代码的形式,可以使用第17行代码输出数据
14)、在代码2中如果在初始化时,使用第11行代码的形式,可以使用第18行代码输出数据
代码如下代码1:
#include <stdio.h>
#include <stdlib.h> void displayArr(int **arr, int size){
for(int i = ; i < size; i++){
printf("%d\t", *(*arr + i));
}
printf("\n"); return;
} int main(int argc, char **argv)
{
int size = ;
int* arrInt[size];
for(int i = ; i < size; i++){
*(arrInt + i) = (int *)malloc(sizeof(int));
*(*arrInt + i) = i + ;
}
displayArr(arrInt, size); return ;
}
再看下面的代码代码2:
#include <stdio.h>
#include <stdlib.h> int main(int argc, char **argv)
{
int size = ;
int* arrInt[size];
for(int i = ; i < size; i++){
arrInt[i] = (int *)malloc(sizeof(int));
//*arrInt[i] = 101 + i;
*(*arrInt + i) = + i;
} for(int i = ; i < size; i++){
//printf("%d\t", arrInt[i][0]);
//printf("%d\t", *arrInt[i]);
//printf("%d\t", *(*arrInt + i));
printf("%d\t", **arrInt + i);
} return ;
}
3、传出,将数组返回
25深入理解C指针之---传递数组的更多相关文章
- 26深入理解C指针之---不规则数组与指针
一.不规则数组:每一行的列数不相等 1.复合字面量: 1).复合字面量是一种C构造 2).外形和数组声明差不多,写法与类型转换一样,(int[3]){10, 20, 30,} 3).将多个复合字面量可 ...
- <深入理解C指针>学习笔记和总结 第四章 指针和数组
数组是一个什么玩意: 数组和指针我的理解,有同样之处也有不同之处.因有同样之处,因此一些资料上说,数组和指针本质是同样的.因有不同之处,因此也有一些资料上说,数组和指针是不一样的. 同样之处: 数组名 ...
- 深入理解C指针之四:指针和数组
原文:深入理解C指针之四:指针和数组 数组是C内建的基本数据结构,数组表示法和指针表示法紧密关联.一种常见的错误认识是数组和指针完全可以互换,尽管数组名字有时可以当做指针来用,但数组的名字不是指针.数 ...
- 33深入理解C指针之---通过字符串传递数据
一.传递字符串:在函数的参数列表中,将参数声明为char指针即可实现通过字符串传递参数 1.特征: 1).字符串以char指针的形式传递,一般是const指针传递: 2).使用字符数组声明字符串,调用 ...
- 数组与指针的区别,以及在STL中传递数组/指针
数组和指针在作为实参传入T[] 或T*的形参时没有区别 void f(int pi[]) { cout << sizeof(pi) << endl; } int a[5] = ...
- 23深入理解C指针之---数组的基础
数组是c语言内置的数据结构,数组有一维数组.二维数组和多维数组.使用数组传递数组时,必须传入数组的大小. 一.数组的特征:阐明数组的特点 1.数组要素: 1).数组类型:数组中存储的数据的类型: 2) ...
- 深入理解C指针之五:指针和字符串
原文:深入理解C指针之五:指针和字符串 基础概念 字符串可以分配到内存的不同区域,通常使用指针来支持字符串操作.字符串是以ASCII字符NUL结尾的字符序列.ASCII字符NUL表示为\0.字符串通常 ...
- 深入理解C指针之三:指针和函数
原文:深入理解C指针之三:指针和函数 理解函数和指针的结合使用,需要理解程序栈.大部分现代的块结构语言,比如C,都用到了程序栈来支持函数的运行.调用函数时,会创建函数的栈帧并将其推到程序栈上.函数返回 ...
- C 真正理解二级指针
本文转载自CSDN博主liaoxinmeng,做数据结构时遇到指针方面的问题,想了许久,因此我觉得很有必要复习一下二级指针及其使用 正文如下: 指针是C语言的灵魂,我想对于一级指针大家应该都很熟悉,也 ...
随机推荐
- Python中关于函数的介绍
一.什么是函数 当我们在日常工作中编写代码时,有没有发现这种情况,写了一套代码,却发现里面有很多段代码出现了有规律的重复,这样就不符合一个合格程序员的标准了,一个合格的程序员编写的代码最重 ...
- 嵌入式入门学习笔记3:[转]编译linux
摘自:https://blog.csdn.net/baidu_24256693/article/details/80115354 编译Linux是什么意思? Linux内核是Linux操作系统的核心, ...
- JAVA基础篇—文件与流
处理字节流的抽象类 InputStream 是字节输入流的所有类的超类,一般我们使用它的子类,如FileInputStream等. OutputStream是字节输出流的所有类的超类,一般我们使用它的 ...
- LeetCode(190) Reverse Bits
题目 Reverse bits of a given 32 bits unsigned integer. For example, given input 43261596 (represented ...
- Letters CodeForces - 978C (二分)
Time limit4000 ms Memory limit262144 kB There are nn dormitories in Berland State University, they a ...
- ax=1(%b) 求最小逆元
定理一:如果d = gcd(a, b),则必能找到正的或负的整数x和y,使 d = a*x+ b*y. 定理二:若gcd(a, b) = ,则方程ax ≡ c (mod b)在[, b-]上有唯一解. ...
- huu 1251
#include <iostream> #include <cstdio> #include <cstring> #include <string> # ...
- BZOJ 5336: [TJOI2018]party
状压最长公共子序列的DP数组,一维最多K(15)个数,且相邻两个数的差不超过1,2^15种状态,预处理转移 #include<cstdio> #include<algorithm&g ...
- luogu2893 [USACO08FEB]修路Making the Grade
ref #include <algorithm> #include <iostream> #include <cstring> #include <cstdi ...
- loj2026 「JLOI / SHOI2016」成绩比较
orz #include <iostream> #include <cstdio> using namespace std; typedef long long ll; int ...