热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于结构体内指针所指向的

#include<stdio.h>#include<malloc.h>#includeSeqList.htypedefunsignedintTSeqLi
#include 
#include 
#include "SeqList.h"

typedef unsigned int TSeqListNode;

typedef struct _tag_SeqList
{
int capacity;
int length;
TSeqListNode* node;
} TSeqList;//定义结构体

SeqList* SeqList_Create(int capacity) // 传递创建的总数   O(1)
{
TSeqList* ret = NULL;//创建结构体指针

if (capacity >= 0)//总数肯定要大于0的
{
ret = (TSeqList*)malloc(sizeof(TSeqList)+sizeof(TSeqListNode)* capacity);
//分配空间一个结构体的空间加上后面数组空间
}

if (ret != NULL)//判断是否创建失败
{
ret->capacity = capacity;
ret->length = 0;
ret->node = (TSeqListNode*)(ret + 1);//创建一个unsigned int 指针
}

return ret;
}

void SeqList_Destroy(SeqList* list) // O(1)//创建void *list;
{
free(list);
}

void SeqList_Clear(SeqList* list) // O(1)//线性表清零
{
TSeqList* sList = (TSeqList*)list;

if (sList != NULL)
{
sList->length = 0;//把长度清零
}
}

int SeqList_Length(SeqList* list) // 得到其线性表长度 O(1)
{
TSeqList* sList = (TSeqList*)list;
int ret = -1;

if (sList != NULL)
{
ret = sList->length;//
}

return ret;
}

int SeqList_Capacity(SeqList* list) //总数  O(1)
{
TSeqList* sList = (TSeqList*)list;
int ret = -1;

if (sList != NULL)
{
ret = sList->capacity;
}

return ret;
}
                 //传入结构指针,和数据地址,还有 位置
int SeqList_Insert(SeqList* list, SeqListNode* node, int pos) // 插入O(n) 
{
TSeqList* sList = (TSeqList*)list;
int ret = (sList != NULL);
int i = 0;

ret = ret && (sList->length + 1 <= sList->capacity);
ret = ret && (0 <= pos);//表示线性表创建成功

if (ret)
{
if (pos >= sList->length)//如果插入位置大于长度
{
pos = sList->length;//就把插入位置放在最后一个
}

for (i = sList->length; i>pos; i--)
{
sList->node[i] = sList->node[i - 1];//向后移动位置,然后插入
}

sList->node[i] = (TSeqListNode)node;//数据就插入这个位置

sList->length++;
}

return ret;
}

SeqListNode* SeqList_Get(SeqList* list, int pos) // O(1) 得到其元素
{
TSeqList* sList = (TSeqList*)list;//又创建一个结构体指针
SeqListNode* ret = NULL;//创建空指针

if ((sList != NULL) && (0 <= pos) && (pos < sList->length))
{
ret = (SeqListNode*)(sList->node[pos]);// (SeqListNode*)(sList->node[pos]);这为毛是地址,不是一个数组中的值吗,这是为毛
}

return ret;
}

SeqListNode* SeqList_Delete(SeqList* list, int pos) // O(n)
{
TSeqList* sList = (TSeqList*)list;
SeqListNode* ret = SeqList_Get(list, pos);
int i = 0;

if (ret != NULL)
{
for (i = pos + 1; ilength; i++)
{
sList->node[i - 1] = sList->node[i];
}

sList->length--;
}

return ret;
}

// (SeqListNode*)(sList->node[pos]);这为毛是地址,不是一个数组中的值吗,大神求解,哇,这然道不是一个值吗

5 个解决方案

#1


没有看到SeqListNode的结构,不过显然是把sList->node[pos]整型值强转成指针了,或许作者用整型变量存储地址了!这是其一
如果SeqListNode是一个unsigned int类型,那么sList->node + pos更合理,也不需要类型转换。

#2


指针还是用指针来存比较好,比竟有16位地址,32位地址,64位地址等不同
楼主可以发下SeqListNode的定义 

#3


注意看 
①、
20行         ret = (TSeqList*)malloc(sizeof(TSeqList)+sizeof(TSeqListNode)* capacity);
28行         ret->node = (TSeqListNode*)(ret + 1);//创建一个unsigned int 指针

②、
75行 int SeqList_Insert(SeqList* list, SeqListNode* node, int pos) // 插入O(n) 
{
.
96行 sList->node[i] = (TSeqListNode)node;//数据就插入这个位置
.
}
由这两处可以看出 其存储的确实就对象的指针,获取的时候必然也就是对象的指针喽
同时我可以肯定,在对象释放的时候 肯定还要释放node指针对应的内存,不然就内存泄露了!!!

这是数据结构存储对象的常用方式,一般都是存储指针,并且该指针的对象一般都是动态开辟出来的内存,不然所指对象生命周期结束,被释放了,那么该指针就成野指针了!

#4


引用 3 楼 zhangsongtao123 的回复:
注意看 
①、
20行         ret = (TSeqList*)malloc(sizeof(TSeqList)+sizeof(TSeqListNode)* capacity);
28行         ret->node = (TSeqListNode*)(ret + 1);//创建一个unsigned int 指针

②、
75行 int SeqList_Insert(SeqList* list, SeqListNode* node, int pos) // 插入O(n) 
{
.
96行 sList->node[i] = (TSeqListNode)node;//数据就插入这个位置
.
}
由这两处可以看出 其存储的确实就对象的指针,获取的时候必然也就是对象的指针喽
同时我可以肯定,在对象释放的时候 肯定还要释放node指针对应的内存,不然就内存泄露了!!!

这是数据结构存储对象的常用方式,一般都是存储指针,并且该指针的对象一般都是动态开辟出来的内存,不然所指对象生命周期结束,被释放了,那么该指针就成野指针了!
谢谢我已经懂了,我觉得他把数组元素赋值成地址,开始还不如创建一个指针数组int **node来代替那样,这样更容易理解,对吗,我感觉这样更好,请问这样可不可以

#5


引用 4 楼 u011391093 的回复:
Quote: 引用 3 楼 zhangsongtao123 的回复:

注意看 
①、
20行         ret = (TSeqList*)malloc(sizeof(TSeqList)+sizeof(TSeqListNode)* capacity);
28行         ret->node = (TSeqListNode*)(ret + 1);//创建一个unsigned int 指针

②、
75行 int SeqList_Insert(SeqList* list, SeqListNode* node, int pos) // 插入O(n) 
{
.
96行 sList->node[i] = (TSeqListNode)node;//数据就插入这个位置
.
}
由这两处可以看出 其存储的确实就对象的指针,获取的时候必然也就是对象的指针喽
同时我可以肯定,在对象释放的时候 肯定还要释放node指针对应的内存,不然就内存泄露了!!!

这是数据结构存储对象的常用方式,一般都是存储指针,并且该指针的对象一般都是动态开辟出来的内存,不然所指对象生命周期结束,被释放了,那么该指针就成野指针了!
谢谢我已经懂了,我觉得他把数组元素赋值成地址,开始还不如创建一个指针数组int **node来代替那样,这样更容易理解,对吗,我感觉这样更好,请问这样可不可以


SeqList* SeqList_Create(int capacity) // 传递创建的总数   O(1)
{
    TSeqList* ret = NULL;//创建结构体指针
 
    if (capacity >= 0)//总数肯定要大于0的
    {
        ret = (TSeqList*)malloc(sizeof(TSeqList)+sizeof(TSeqListNode)* capacity);
        //分配空间一个结构体的空间加上后面数组空间
    }
 
    if (ret != NULL)//判断是否创建失败
    {
        ret->capacity = capacity;
        ret->length = 0;
        ret->node = (TSeqListNode*)(ret + 1);//创建一个unsigned int 指针
    }
 
    return ret;
}
由创建的函数可以知道,node指针的所知内存大小以及数据的数量是动态指定,因为new的时候是一块连续的空间,这样做的目的是方便释放内存。 如果按照你的意思,用一串连续的指针来存储数据,不是不可以,是因为难维护,释放的时候还要便利分别释放。
 提示一点 int **node 可不是数组指针,自己去查查

推荐阅读
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 本文将详细探讨Linux pinctrl子系统的各个关键数据结构,帮助读者深入了解其内部机制。通过分析这些数据结构及其相互关系,我们将进一步理解pinctrl子系统的工作原理和设计思路。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
  • JSOI2010 蔬菜庆典:树结构中的无限大权值问题
    本文探讨了 JSOI2010 的蔬菜庆典问题,主要关注如何处理非根非叶子节点的无限大权值情况。通过分析根节点及其子树的特性,提出了有效的解决方案,并详细解释了算法的实现过程。 ... [详细]
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 使用lambda表达式排序Collections.sort(temp,(Stringa,Stringb)-{returnb.compareTo(a);});Collections ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
author-avatar
aaaaaaaaaa本尊
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有