数组名表示的是这个数组的首地址。即如果有int a[10],则a 相当于&a[0]。

#include <stdio.h>
main() {
int a[5]= {1,3,5,7,9};
printf("数组a[]的地址为:%d\n",a); for(int i=0; i<10; i++) {
printf("a[%d]的地址为:%d \n",i, &a[i]);
}
}

运行结果:

数组a[]的地址为:6487600
a[0]的地址为:6487600
a[1]的地址为:6487604
a[2]的地址为:6487608
a[3]的地址为:6487612
a[4]的地址为:6487616
a[5]的地址为:6487620
a[6]的地址为:6487624
a[7]的地址为:6487628
a[8]的地址为:6487632
a[9]的地址为:6487636

指针操作数组元素

#include <stdio.h>
main() {
int a[]= {1,3,5,7,9};
int *p = NULL; p = a;
printf("数组名赋值给指针:%d\n", *p); p = &a[0];
printf("指针指向数组首元素:%d\n", *p); p = &a[2];
printf("针指向数组任意元素:%d\n", *p); // 指针加上整数,相当于数组下标加上整数
// p+j = a[i+j]
printf("指针加上整数:%d\n", *(p+1));// a[2+1]
}

运行结果:

数组名赋值给指针:1
指针指向数组首元素:1
针指向数组任意元素:5
指针加上整数:7

指针遍历数组

#include <stdio.h>
main() {
int a[5]= {1,3,5,7,9};
int nLen = sizeof(a)/sizeof(int);
int *p=a;
int *q;
q=p; for(p; p-q<nLen; p++) {
printf("%d ",*p);
}
}

函数封装版:

#include <stdio.h>

void printArray(int *p,int len) {
int *q = p;
for(p; p-q<len; p++) {
printf("%d ",*p);
} printf("\n");
} main() {
int a[5]= {1,3,5,7,9};
printArray(a, 5);
}

指针版求字符串长度

#include <stdio.h>
#include <string.h>
int myStrlen(char *s) {
int n = 0;
while(*s !='\0') {
n++;
s++;
}
return n;
} main() {
char str1[200];
strcpy(str1,"大话西游2");
printf("%d\n", myStrlen(str1));
printf("%s", (str1));
}

指针版字符串常量

“指针版”字符串常量可像数组一样输出,不能修改,但可以直接赋值。

#include <stdio.h>
main() {
char astr[] = "hello world";// 普通字符串常量(即字符数组)
char *pstr = "hello world";// 指针版字符串常量 // “指针版”可像数组一样输出
printf("%c %c", astr[0], pstr[0]); //X:“指针版”不能修改:pstr[0] = 'c';
astr[0] = 'c'; printf("\n %s\n", pstr);
printf("\n %s\n", astr); //X:字符数组不能直接赋值:astr = "wellcome c";
pstr = "wellcome to c";// “指针版”可以直接赋值
printf("\n %s\n", pstr);
}

指针版字符串复制

#include <stdio.h>
void copy_str(char *strFrom , char *strTo) {
while(*strFrom != '\0') {
*strTo = *strFrom;
strTo ++;
strFrom ++;
}
*strTo = '\0';
} main() {
char* strFrom = "一生事业总成空,\
半世功名在梦中。\
死后不愁无勇将,\
忠魂依旧守辽东。";
char strTo[200] = {0};
copy_str(strFrom, strTo);
puts(strTo);
}

字符串转置

#include <stdio.h>
#include <string.h>
main() {
char str[] = "pool";
char *p1 = str;
char *p2 = str + strlen(str) - 1; char temp ;
while (p1 < p2) {
temp = *p1;
*p1 = *p2;
*p2 = temp;
p1++;
p2--;
}
puts(str);
}

指针数组

指针的数组。

#include <stdio.h>
main() {
char* pName[] = {"1.关胜","2.林冲","3.秦明","4.呼延灼","5.董平"};
printf("指针长度:%d \n", sizeof(char*));
printf("指针数组长度:%d \n", sizeof(pName)); int i;
for( i= 0; i<5; i++) {
puts(pName[i]);
}
puts("---------------");
char* temp = pName[0];
pName[0] = pName[4]; // 改变指向
for( i= 0; i<5; i++) {
puts(pName[i]);
}
printf("temp = %s", temp);
}

运行结果:

指针长度:8
指针数组长度:40
1.关胜
2.林冲
3.秦明
4.呼延灼
5.董平
---------------
5.董平
2.林冲
3.秦明
4.呼延灼
5.董平
temp = 1.关胜

C语言讲义——数组和指针的更多相关文章

  1. C语言中数组与指针的异同之处!你不知道的编程奥秘~

    C语言的数组和指针一直是两个容易混淆的东西,当初在学习的时候,也许为了通过考试会对指针和数组的一些考点进行突击,但是很多极其细节的东西也许并不是那么清楚.本篇侧重点在于分析数组与指针的关系,什么时候数 ...

  2. C语言之数组与指针的易混淆知识点

    一.指针与数组 指针:指针本身也是一个变量,它的内容是指向的内容的地址.指针同样有类型的区分,char 的指针只能指向char型数据,int 指针指向int型数据.但是指针所占内存单元的大小(即其内容 ...

  3. [C语言基础] 数组与指针之间的引用

    通过指针引用数组,通过数组引用指针,你搞明白了么?通过下面3种情形来了解一下数组和指针 Case 1. unsigned char arry[10]; unsigned char *ptr; unsi ...

  4. c语言,数组和指针

    概要: 1.普通数组与指针 2.数组指针 3.指针的数组 数组是一个由(同一类型)连续元素组成的预先分配的内存块:指针是一个对任何位置的元素的引用. 数组自动分配空间,但不能重分配或改变大小:指针必须 ...

  5. 由strcat函数引发的C语言中数组和指针问题的思考

    问题一 首先,来看一下下面这段代码: #include <stdio.h> #include <string.h> int main() { char *str = " ...

  6. c语言中数组,指针数组,数组指针,二维数组指针

    1.数组和指针 ] = {,,,,};// 定义数组 // 1. 指针和数组的关系 int * pa = array; pa = array; // p[0] == *(p+0) == array[0 ...

  7. c语言字符数组和指针的经典用法

    1.字符数组 许多情况下,对字符串的处理使用字符数组会更加方便,比如: 我觉得不改变字符串的原有顺序,对字符串进行删除等操作时,使用字符数组效果会更好. eg:给定字符串(ASCII码0-255)数组 ...

  8. (四)C语言柔性数组、指针赋值

    一.柔性数组 今天看了公司的代码,发现一个很奇怪的问题,后来自己写了类似代码,我先把代码贴出来吧. #include<stdio.h> #include<string.h> # ...

  9. C语言讲义——数组

    数组是: 一组数据 一组类型相同的数据 在计算机底层,数组是一块连续的内存 为什么使用数组? 一年12个月 int m1=1, m2=2, m3=3, ... 麻烦 数组示例: #include &l ...

随机推荐

  1. B. Two Arrays 解析(思維)

    Codeforce 1417 B. Two Arrays 解析(思維) 今天我們來看看CF1417B 題目連結 題目 略,請直接看原題. 前言 a @copyright petjelinux 版權所有 ...

  2. C语言之 Switch和?:运算符的反汇编

    Switch条件语句 通过上面一篇了解了条件语句的使用,接下来就直接进行反汇编学习 #include <stdio.h> void print() { int b = 1; switch ...

  3. CSS动画之转换模块

    2D转换模块:注意点:1.可以类似于过渡模块一样简写,但是这里不是用逗号隔开而是用空格 2.2D的转换模块会修改元素的坐标系,所以旋转之后的平移就不是水平平移 格式:旋转:transform: rot ...

  4. 2.3 spring5源码系列---内置的后置处理器PostProcess加载源码

    本文涉及主题 1. BeanFactoryPostProcessor调用过程源码剖析 2. 配置类的解析过程源码 3. 配置类@Configuration加与不加的区别 4. 重复beanName的覆 ...

  5. NB-IoT和LORA技术通信距离是一样的吗

    如今物联网的无线通信技术非常多,这其中主要分为两大类:一类是以Zigbee.WiFi.蓝牙.Z-wave等短距离通信技术为主:另一类就是以LPWAN(low-powerWide-AreaNetwork ...

  6. 排序算法—快速排序(Quick Sort)

    快速排序(Quick Sort) 快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. ...

  7. 用spring-retry注解自动触发重试方法

    原文地址:https://www.jianshu.com/p/ee02d6125113 需求背景: 有些时候我们再调用一些第三方服务的时候,从第三方那边拉数据. 但是第三方服务不是100%稳定的,有些 ...

  8. VSCode--HTML代码片段(基础版,react、vue、jquery)

    起因是最近在学习前端,看的网上的demo也是在react.vue.jquery之间穿插,为了方便一键生成html模板(懒)写demo,有了以下折腾. 本人使用的前端编辑工具是vscode(方便.懒), ...

  9. leetcode 38:path-sum

    题目描述 给定一个二叉树和一个值sum,判断是否有从根节点到叶子节点的节点值之和等于sum的路径, 例如: 给出如下的二叉树,sum=22,              5              / ...

  10. Linux C 获取本机所有网卡的 IP,Mask

    0 运行环境 本机系统:Windows 10 虚拟机软件:Oracle VM VirtualBox 6 虚拟机系统:Ubuntu 18 1 代码 #include <sys/ioctl.h> ...