【C语言】结构体指针

这篇具有很好参考价值的文章主要介绍了【C语言】结构体指针。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

结构体

基础知识

初识结构体,可以先看这篇浅显易懂的文章结构体–基础篇
所谓结构体,是一组类型可以不同的相关变量(或数组)的集合。
构成结构体的变量(或数组)称为结构体的成员
C语言要求,在定义结构体变量时,需要明确给定每个成员的名字类型
声明一种·结构体类型,需要定义一个标识符,这种标识符称为结构体类型标识符。

struct student
{
    char name[20];
    char num[11];
    int age;
    float score;
};//student 是结构体类型的标识符    
//struct student 是一种结构体类型

对于结构体变量的成员可以进行哪些操作,取决于结构体变量的成员是哪种类型的。因为结构体变量的成员在本质上也是变量(或数组),所以对于结构体变量成员的操作,与同类型变量(或数组)的操作是相同的。

注意对于成员的赋值

我们先来看一个错误的程序:

#include <stdio.h>
struct student 
{
	char name[20];
	char num[20];
	int score;
};
int main (void)
{
	struct student stu;
	stu.score=99;
	stu.name="Lin hui";
	stu.num="S2208017";
	printf("%d,%s,%s\n",stu.score,stu.name,stu.num);
	return 0;
}

编译系统会报错,这是为什么呢?
该程序编译时,将会产生“给数组名赋值”的错误。
这是因为结构体变量stu的两个成员num和name均为字符数组
而数组名属于指针常量,因而不能对数组名进行赋值。
那么,如何才能将字符串存放如字符数组成员中呢?我们可以利用strcpy函数。
正确的程序:

#include <stdio.h>
#include <string.h>
struct student 
{
	char name[20];
	char num[20];
	int score;
};
int main (void)
{
	struct student stu;
	stu.score=99;
	strcpy(stu.name,"Linhui");
	strcpy(stu.num,"S2208017");
	printf("%d,%s,%s\n",stu.score,stu.name,stu.num);
	return 0;
}

结构体指针

指针的基本功能就是间接引用,也就是通过指针变量间接地引用另一个变量。

为什么要使用指针呢?
指针的独特优势在于,在C语言中的某些功能只能借助于间接引用才能实现。
例如,局部变量的跨函数改写,就只能通过间接引用才能实现。

同样地,结构体指针的功能就是间接地引用结构体变量。
而C语言中的某些功能(例如动态链表)就必须借助于结构体指针才能实现。

指向结构体变量的指针

struct student    //声明结构体类型
{
    char name[20];
    char num[20];
    int age;
    int score;
};
struct student stu;//定义结构体类型的变量stu
struct *p;//定义指向结构体变量的指针变量p
p=&stu;//赋初值

结构体指针与结构体成员指针

一旦定义了指向结构体变量的指针,就可以通过该指针间接引用所指向的结构体变量。

p=&stu;

那么,就可以用*p来间接引用结构体变量stu;
上述是把结构体变量的首地址赋值给指针变量p,所以结构体指针变量p指向了结构体变量stu。
例:
c语言结构体指针,C语言,c语言,数据结构,c++
虽然结构体指针和结构体第一个成员的地址值相同,但结构体指针结构体成员指针的含义是不同的。

struct student *p;*p=stu;
int *p1=stu.num;

虽然p和p1的值是相同的,都是2000H。但是p是指向结构体类型变量的指针,而p1是指向int型变量的指针。若执行p++,则p的值为2043H,而执行p1++,p1的值为2002H。

用结构体指针引用结构体成员

既然可以利用结构体指针引用结构体变量,当然也可以引用结构体变量的成员
其一般形式为:

(*结构体指针变量).成员名

需要注意,这里的括号必不可少。如果去掉括号后:

*结构体指针变量.成员名

由于成员运算符“.”的优先级高于间接引用运算符"*",所以上式即为:

*(结构体指针变量.成员名)

而指针变量不可能有成员,从而导致语法错误。
例:
从键盘输入一个学生的学号、姓名、年龄和成绩,并存入一个结构体变量中,然后依次输出各项数据。要求通过结构体指针``间接引用该结构体变量的成员`。

#include <stdio.h>
struct student   //定义结构体类型说明符 student
{
    char num[20];
    char name[20];
    int age;
    float score;
};
int main (void)
{
    struct student stu,*p=&stu;
    gets((*p).num);//输入学号
    gets((*p).name);//输入姓名
    scanf("%d",&(*p).age);//输入年龄
    scanf("%f",&(*p).score);//输入成绩
    printf("学号\t姓名\t年龄\t成绩\n");
    printf("%s\t%s\t%d\t%.2f\n",(*p).num,(*p).name,(*p).age,(*p).score);
    return 0;
}

上述间接引用形式比较直观,但略显繁琐,故C语言提供了另一种更加简洁的·引用形式。
其一般形式为:

结构体指针变量->成员名

此处的“- >”称为指向运算符。
其功能等价于:

(*结构体指针变量).成员名

让我们再来以这种方式做一下上面的题目:
从键盘输入一个学生的学号、姓名、年龄和成绩,并存入一个结构体变量中,然后依次输出各项数据。要求通过结构体指针``间接引用该结构体变量的成员`。文章来源地址https://www.toymoban.com/news/detail-763819.html

#include <stdio.h>
struct student //定义结构体类型说明符
{
    char num[20];
    char name[20];
    int age;
    float score;
};
int main (void)
{
    struct student stu,*p=&stu;
    gets(p->num);
    gets(p->name);
    scanf("%d",&p->age);
    scanf("%f",&p->score);
    printf("学号\t姓名\t年龄\t成绩\n");
    printf("%s\t%s\t%d\t%.2f\n",p->num,p->name,p->age,p->score);
    return 0;
}

到了这里,关于【C语言】结构体指针的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【开卷数据结构 】指针的初步认识

    说到指针,想必大家都不陌生,指针的最大特点就是难以理解,它是编程中很基础也是很重要的概念,指针可以有效的实现像树,链表这类高级的数据结构。 在了解指针是什么之前,我们需要先了解什么是计算机的内存,什么是地址。 内存: 计算机内存大部分时候指的是随

    2023年04月16日
    浏览(35)
  • 【数据结构与算法】之多指针算法经典问题

    本文为 【数据结构与算法】多指针算法经典问题 相关介绍,下边将对 链表反转 (包含 迭代反转链表 、 递归反转 、 头插法反转 ), 双指针-快慢指针 (包含 寻找单向无环链表的中点 、 判断单向链表是否有环及找环入口 ), 双指针-左右指针 (包含 两数之和 、 二分查

    2024年02月03日
    浏览(31)
  • 【数据结构】双向链表 超详细 (含:何时用一级指针或二级指针;指针域的指针是否要释放)

    目录 一、简介 二. 双链表的实现 1.准备工作及其注意事项 1.1 先创建三个文件 1.2 注意事项:帮助高效记忆 1.3   关于什么时候 用 一级指针接收,什么时候用 二级指针接收? 1.4 释放节点时,要将节点地址 置为NULL,难道 节点内部的 指针域的指针 就不用置为 NULL吗?  2.双链

    2024年02月20日
    浏览(73)
  • 【C/C++数据结构】链表与快慢指针

    目录 一、单链表 二、双向循环链表 三、判断链表是否带环 四、链表的回文结构判断 五、复制带随机指针的链表 优点 :头部增删效率高,动态存储无空间浪费 缺点 :尾部增删、遍历效率低,不支持随机访问节点 头结点 :单链表头结点可有可无,带头结点更方便进行初始

    2024年02月16日
    浏览(31)
  • 【数据结构】[LeetCode138. 复制带随机指针的链表]

    给你一个长度为  n  的链表,每个节点包含一个额外增加的随机指针  random  ,该指针可以指向链表中的任何节点或空节点。 构造这个链表的  深拷贝 。 深拷贝应该正好由  n  个  全新  节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的  next  指针和

    2024年02月04日
    浏览(31)
  • 【数据结构OJ题】复制带随机指针的链表

    原题链接:https://leetcode.cn/problems/copy-list-with-random-pointer/description/ 目录 1. 题目描述 2. 思路分析 3. 代码实现 此题可以分三步进行: 1. 拷贝链表的每一个结点,拷贝的结点先链接到被拷贝结点的后面。 2. 复制随机指针的链接:拷贝结点的随机指针指向被拷贝结点随机指针的下

    2024年02月12日
    浏览(30)
  • 数据结构与算法----复习Part 8 (链表双指针)

    本系列是算法通关手册LeeCode的学习笔记 算法通关手册(LeetCode) | 算法通关手册(LeetCode) (itcharge.cn) 本系列为自用笔记,如有版权问题,请私聊我删除。 目录 一,双指针简介(Two Pointers) 二,起点不一致的快慢指针 三,步长不一致的快慢指针 判断链表中是否含有环: 四

    2024年02月19日
    浏览(38)
  • 【数据结构】两两交换链表 && 复制带随机指针的链表

    给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。 使用一个栈S来存储相邻两个节点即可 给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以

    2024年04月15日
    浏览(33)
  • 【LeetCode】数据结构题解(9)[复制带随机指针的链表]

    所属专栏:玩转数据结构题型❤️ 🚀 博主首页:初阳785❤️ 🚀 代码托管:chuyang785❤️ 🚀 感谢大家的支持,您的点赞和关注是对我最大的支持!!!❤️ 🚀 博主也会更加的努力,创作出更优质的博文!!❤️ 🚀 关注我,关注我,关注我,重要的事情说三遍!!!!!

    2024年02月11日
    浏览(39)
  • 手撕数据结构与算法——树(三指针描述一棵树)

    📖作者介绍:22级树莓人(计算机专业),热爱编程<目前在c++阶段, 因为最近参加新星计划算法赛道(白佬),所以加快了脚步,果然急迫感会增加动力 ——目标Windows,MySQL,Qt,数据结构与算法,Linux,多线程,会持续分享学习成果和小项目的 📖作者主页:king南星 📖

    2024年01月17日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包