首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么我不能使用指针加法而不是malloc

指针加法和malloc是两个不同的概念,它们在内存管理中有着不同的作用和用途。

指针加法是一种对指针进行算术操作的方式,用于在内存中移动指针的位置。通过指针加法,可以方便地遍历数组或者访问连续内存块中的元素。例如,可以使用指针加法来遍历一个整型数组,或者在字符串中定位特定的字符。

而malloc是C/C++语言中的一种内存分配函数,用于动态分配内存空间。通过调用malloc函数,可以在运行时动态地分配所需大小的内存。这样可以避免静态分配内存时的浪费和不确定性。

为什么不能只使用指针加法而不是malloc呢?原因如下:

  1. 内存大小不确定:使用指针加法无法确定所需的内存大小,无法灵活地分配和释放内存空间。而malloc可以根据需要动态地分配内存空间,并在使用后释放。
  2. 内存安全性:指针加法可能导致内存越界访问,因为无法准确地确定内存边界。而malloc会分配一块连续的内存空间,并确保访问的内存范围不会越界,提高了内存的安全性。
  3. 内存泄漏:使用指针加法无法释放已分配的内存空间,可能导致内存泄漏。而malloc可以在不需要内存空间时进行释放,避免了内存泄漏问题。

总结起来,指针加法适用于遍历数组、字符串等情况下对内存进行访问,而malloc适用于动态分配和释放内存空间的情况。两者在功能和用途上是不可替代的。

腾讯云相关产品和产品介绍链接地址请参考腾讯云官方网站:https://cloud.tencent.com/

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 算法与数据结构之四----双向链表

    /**************************************************************** 文件内容:线性表之循环链表操作 版本V1.0 说明:单链表必需从头结点开始遍历,而双链表可以可以往前后两个方向都可以遍历 1.赋值和指向方向不能搞错 A 赋值给B ,说明B指向A 2.双向链表跟普通链表操作思想一样,只不过多了一个前驱指针而已。 思路完全一致。 作者:HFL 时间:2013-12-29  *****************************************************************/  #include<stdio.h> #include<malloc.h> #include <windows.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif typedef struct DNode { INT32 data; struct DNode *prior,*next; }Dnode,*Linklist; /**************************************************************** 函数功能:创建一个节点                         输入参数:  无 返回值:节点的指针  作者:HFL  时间:2013-12-22  *****************************************************************/ Linklist Creat_DNode(INT32 X) {  Linklist s;       s=(struct DNode *)malloc(sizeof(DNode));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); s->data = X; } return s; } /**************************************************************** 函数功能:初始化链表1(即头部创建一个链表)                         输入参数:  无 返回值:链表的标头指针  作者:HFL  时间:2013-12-29  *****************************************************************/  Linklist Head_Creat_Linklist() { Linklist L=NULL; DNode *s; INT32 x;     scanf("%d",&x); while(x!=0) {  s=(struct DNode *)malloc(sizeof(DNode));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n");    s->next = L;    s->data = x ; if ( NULL != L) { L->prior = s; /*第一个节点再没有后面的节点了*/ } L = s; s->prior = L; scanf("%d",&x); } } return L; } /**************************************************************** 函数功能:初始化链

    03

    算法与数据结构之三----循环链表

    /**************************************************************** 文件内容:线性表之循环链表操作 版本V1.0 说明:单链表必需从头结点开始遍历,而循环链表可以从任何地方都可以遍历,只不过只能想后遍历 循环链表的特点: 1.链表头指针和尾指针相接,也就是说没有头指针,也没有尾指针(也没有NULL指针,单链表尾指针为NULL) 2.从任何一个地方开始遍历都可以找到某一个节点X 创建方法: 方法1.先建立两个单链表,然后将一个单链表的头指针链接到另外一个单链表的尾指针。 方法2:在后插入法建立单链表的基础上,每创建一个节点,尾指针总是指向头指针。 判断一个链表是否是循环链表的方法: 对链表进行遍历,如果能找到某个指针域指向NULL,则为单链表,否则就是双链表 循环链表特性: 1.循环链表无法求长度,因为是无限长度的 2.循环链表是无法遍历完毕的,因为是无限长度的 3.循环链表插入,删除,查找跟单链表没有任何区别,只不过单链表有头指针,循环链表没有 头指针,或者说循环链表中任意一个节点指针都是头指针。 作者:HFL 时间:2013-12-25  *****************************************************************/  #include<stdio.h> #include<malloc.h> #include <windows.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif typedef struct CNode { INT32 data; struct CNode *next; }Cnode,*Linklist; /**************************************************************** 函数功能:创建一个循环链表,由单链表中初始化链表2(即尾部创建一个链表)派生而来                         输入参数:  无 返回值:链表的标头指针  说明:要引入一个新的指针变量,用于链接前后节点       在后插入建立单链表的基础上,每次创建一个节点,就将尾指针指向头指针 作者:HFL  时间:2013-12-24  ************T*****************************************************/  Linklist Creat_Clinklist() { Linklist L=NULL; Cnode *s; Cnode *probe =NULL; INT32 x;     scanf("%d",&x); while(x!=0) {  s=(struct CNode *)malloc(sizeof(Cnode));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); if(L== NULL) { L = s;  //第一个节点就必需保存投节点 } else { probe->next = s; //第二个节点开始,要引入一个临时指针,来暂存上一个节点地址,一遍链接前后两个节点 } probe = s;  //每次创建一个新节点,节点都必需重新移动。 s->data = x ; s->next = L; scanf("%d",&x); } } return L; } /*******************************************************

    01

    算法与数据结构之二-------单链表

    /**************************************************************** 文件内容:线性表之单链表操作 版本V1.0 说明:针对单链表,插入和删除,最好从P节点后面插入或删除操作,避免P节点前面操作。 因为前位操作,需要找前驱,单链表找前驱又要从节点头部遍历开始,效率太低。 后面因为这个效率原因,引入了双向链表,而双向链表就本身带前驱,操作更方便快捷。 作者:HFL 时间:2013-12-22  *****************************************************************/  #include<stdio.h> #include<stdlib.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif /*************************************************************** 因为struct Node 与LNode 和*Linklist 是互为别名,因此以下写法是等效的 struct Node *s等于 LNode *s     等于 Linklist s ****************************************************************/ #ifndef TRIDiTION   typedef  struct Node {     INT32 data;    struct Node *next; } LNode, * Linklist; #else struct Node { INT32 data; struct Node *next; }; #endif /**************************************************************** 函数功能:创建一个节点                         输入参数:  无 返回值:节点的指针  作者:HFL  时间:2013-12-22  *****************************************************************/ Linklist Creat_Node(INT32 X) {  Linklist s;       s=(struct Node *)malloc(sizeof(LNode));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); s->data = X; } return s; } /**************************************************************** 函数功能:初始化链表1(即头部创建一个链表)                         输入参数:  无 返回值:链表的标头指针  作者:HFL  时间:2013-12-22  *****************************************************************/  Linklist Head_Creat_Linklist() { Linklist L=NULL; LNode *s; INT32 x;     scanf("%d",&x); while(x!=0) {  s=(struct Node *)malloc(sizeof(LNode));  if(NULL==s) { Log(" sorry,Mallo

    02

    算法与数据结构之八----链队

    /**************************************************************** 文件内容:线性表之链队操作 版本V1.0 作者:HFL 时间:2013-12-22  *****************************************************************/  #include<stdio.h> #include<stdlib.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif typedef struct Node { INT32 data;     struct Node * next; }linksequeue, * LkSq; typedef struct Pointer {   LkSq Rear;   LkSq Front; }Hander; Hander * p = NULL; /**************************************************************** 函数功能:创建一个节点                         输入参数:  无 返回值:节点的指针  作者:HFL  时间:2013-12-22  *****************************************************************/  LkSq Creat_Node(INT32 X) {  LkSq s;       s=(struct Node *)malloc(sizeof(Node));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); s->data = X; } return s; }  /**************************************************************** 函数功能:初始化链队                        输入参数:  无 返回值: 链队的队顶指针指针  作者:HFL  时间:2013-12-29  *****************************************************************/   LkSq Init_Linkqueue() {       LkSq q = NULL; q = (struct Node *)malloc(sizeof(struct Node)); if(NULL== q) { Log(" sorry,Malloc Node is failed\n"); } p = (struct Pointer *)malloc(sizeof(struct Pointer)); if(NULL== p) { Log(" sorry,Malloc Hander is failed\n"); } p->Front = q; p->Rear = q; q->next = NULL; return q; } /**************************************************************** 函数功能:判断链队是否为空队                        输入参数:  无 返回值: 链队的标头指针  说明:链队是由链来实现,所有的操作方式都是跟链表一样,只是某些操作堆队来说是 非法的。 作者:HFL  时间:2013-12-29  **

    02

    超详细的链表学习

    -----想必大多数人和我一样,刚开始学数据结构中的单链表还是蛮吃力的,特别是后面的双链表操作更是如此。还有就是在实践代码操作时,你又会感到无从下手,没有思路。造成这样的缘由,还是没有完全把链表吃透,今天刚好看书又看到了这里,总结一下,分享给大家,希望对大家有帮助。 一、链表引入的缘由: 在一开始,不知大家用了这么久的数组,你有没有发现数组存在两个明显的缺陷?1)一个是数组中所有元素的类型必须一致;2)第二个是数组的元素个数必须事先制定并且一旦指定之后不能更改。于是乎为了解决数组的缺陷,先辈们发明的一些特殊方法来解决:a、数组的第一个缺陷靠结构体去解决。结构体允许其中的元素的类型不相同,因此解决了数组的第一个缺陷。所以说结构体是因为数组不能解决某些问题所以才发明的;b、我们希望数组的大小能够实时扩展。譬如我刚开始定了一个元素个数是10,后来程序运行时觉得不够因此动态扩展为20.普通的数组显然不行,我们可以对数组进行封装以达到这种目的;我们还可以使用一个新的数据结构来解决,这个新的数据结构就是链表(几乎可以这样理解:链表就是一个元素个数可以实时变大/变小的数组)。 二、什么是链表? 顾名思义,链表就是用锁链连接起来的表。这里的表指的是一个一个的节点(一个节点可以比喻成大楼里面的空房子一样用来存放东西的),节点中有一些内存可以用来存储数据(所以叫表,表就是数据表);这里的锁链指的是链接各个表的方法,C语言中用来连接2个表(其实就是2块内存)的方法就是指针。它的特点是:它是由若干个节点组成的(链表的各个节点结构是完全类似的),节点是由有效数据和指针组成的。有效数据区域用来存储信息完成任务的,指针区域用于指向链表的下一个节点从而构成链表。 三、单链表中的一些细节: 1、单链表的构成: a、链表是由节点组成的,节点中包含:有效数据和指针。 b、定义的struct node只是一个结构体,本身并没有变量生成,也不占用内存。结构体定义相当于为链表节点定义了一个模板,但是还没有一个节点,将来在实际创建链表时需要一个节点时用这个模板来复制一个即可。例如:

    02

    算法与数据结构之六----链栈

    /**************************************************************** 文件内容:线性表之链栈操作 版本V1.0 作者:HFL 时间:2013-12-22  *****************************************************************/  #include<stdio.h> #include<stdlib.h> //#define RELEASE_VERSION  //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define  Log  #else #define  Log  printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32  typedef unsigned int UINT32 ; #endif #ifndef INT32  typedef  int  INT32 ; #endif #define MAX 12 typedef struct Node { INT32 data;     struct Node * next; }linkstack, * Lkstack; Lkstack Top;// 栈顶指针,相当于头指针,由于栈没有遍历和查找概念,故不引入头指针 /**************************************************************** 函数功能:创建一个节点                         输入参数:  无 返回值:节点的指针  作者:HFL  时间:2013-12-22  *****************************************************************/ Lkstack Creat_Node(INT32 X) {  Lkstack s;       s=(struct Node *)malloc(sizeof(Node));  if(NULL==s) { Log(" sorry,Malloc is failed\n"); } else { Log(" Malloc is successed!\n"); s->data = X; } return s; } /**************************************************************** 函数功能:初始化链栈                        输入参数:  无 返回值: 链栈的栈顶指针指针  作者:HFL  时间:2013-12-29  *****************************************************************/   Lkstack Init_Linkstack() { Top = NULL; return Top; } /**************************************************************** 函数功能:判断链栈是否为空栈                        输入参数:  无 返回值: 链栈的标头指针  说明:链栈是由链来实现,所有的操作方式都是跟链表一样,只是某些操作堆栈来说是 非法的。 作者:HFL  时间:2013-12-29  *****************************************************************/  INT32 Is_Empty_Linkstack() {   if (NULL == Top )   {  Log("sorry,the stack is NULL");  return 0;   }   else   {     return 1;   } } /**************************************************************** 函数功能: 链栈入栈

    03

    算法与数据结构之五----顺序栈

    /**************************************************************** 文件内容:线性表之顺序栈操作 版本V1.0 作者:HFL 时间:2013-12-22 *****************************************************************/ #include<stdio.h> #include<stdlib.h> //#define RELEASE_VERSION //release版本开关 //#define TRIDiTION /*inlude<malloc.h> stdlib.h 包含malloc.h*/ #ifdef RELEASE_VERSION #define Log #else #define Log printf #endif /*为了提高程序的可移植性,千万不能使用裸露的数据类型*/ #ifndef UINT32 typedef unsigned int UINT32 ; #endif #ifndef INT32 typedef int INT32 ; #endif #define MAX 12 typedef struct Seqstack { INT32 data[MAX]; INT32 Top; }seqstack,* Sqstack; /**************************************************************** 函数功能:初始化顺序栈 输入参数: 无 返回值: 顺序的栈的标头指针 说明:顺序栈是由顺序来实现,所有的操作方式都是跟顺序表一样,只是某些操作堆栈来说是 非法的。 作者:HFL 时间:2013-12-29 *****************************************************************/ Sqstack Init_Sqstack() { Sqstack s = NULL; s = (struct Seqstack * )malloc(sizeof (struct Seqstack)); if(NULL) { Log("malloc is failed\n"); } else { Log( "malloc is sucessed \n"); } s->Top = -1; return s; } /**************************************************************** 函数功能:判断顺序栈是否为空栈 输入参数: 无 返回值: 顺序的栈的标头指针 说明:顺序栈是由顺序来实现,所有的操作方式都是跟顺序表一样,只是某些操作堆栈来说是 非法的。 作者:HFL 时间:2013-12-29 *****************************************************************/ INT32 Is_Empty_Seqstack(Sqstack q) { if (-1 == q->Top ) { Log("sorry,the stack is NULL"); return 0; } else { return 1; } } /**************************************************************** 函数功能: 判断顺序栈是否已经满 输入参数: 无 返回值: 顺序的栈的标头指针 说明:顺序栈是由顺序来实现,所有的操作方式都是跟顺序表一样,只是某些操作堆栈来说是 非法的。 作者:HFL 时间:2013-12-29 *****************************************************************/ INT32 Is_Full_Seqstack(Sqstack q) { if (MAX-1 == q->Top ) { Log("sorry,the stack is FULL"); return 0; } else { return 1; } } /********************************************

    01
    领券