C—结构体,动态分配内存存储字符串

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS
#pragma warning(disable:4996);
//上面这一行必须加,否则strcpy不能用

#include<stdio.h>
#include<string.h>

typedef struct LNode {
	char* name;
	int age;
}LNode,*LinkNode;


int main() {
	LNode node;
	LinkNode lnode = (LinkNode)malloc(sizeof(LinkNode));
	if (lnode == NULL) {								/* 检查内存分配是否成功 */
		return -1;
	}
	lnode->age = 20;


	char name1[] = "小时光";
	node.name = (char*)malloc(strlen(name1)+1);				/* node.name 指向了一个具有足够内存空间的字符数组,可以用来存储字符串 name1。 */

	if (node.name == NULL) {								/* 检查内存分配是否成功 */
		return -1;
	}
	strcpy(node.name, name1);
	printf("%s", node.name);

	//防止内存泄漏,在适当的情况下,释放内存
	free(node.name);		
	free(lnode);
	return 0;
}

/*上面的malloc(strlen(name1)+1)可以换成malloc(sizeof(name1))吗?

不可以。在C语言中,sizeof(name1)将返回name1数组的大小(以字节为单位),而不是字符串的长度。
在C语言中,字符串是以null终止的字符数组,所以字符串的长度通常比其分配的内存空间多1字节,用来存储null终止符\0。
因此,使用malloc(strlen(name1) + 1)确保为字符串分配了足够的内存空间,包括字符串中的字符以及null终止符。如果你使用malloc(sizeof(name1)),可能会导致内存越界错误,因为没有为null终止符预留空间,这会导致字符串操作函数(例如strcpy)无法正常工作,从而产生不可预测的结果。所以,在动态分配内存空间给字符串时,一定要确保为null终止符留出足够的空间。*/

动态分配内存空间给结构体成员变量通常在以下情况下使用:

  1. 字符串成员变量: 如果结构体中包含字符串,字符串的长度是不确定的,你可能需要使用动态内存分配来存储字符串,确保足够的空间来容纳字符串内容。

    c 复制代码
    struct Person {
        char* name;
        int age;
    };
  2. 可变大小的数组: 如果结构体包含数组,并且数组的大小是在运行时确定的,你可以使用动态内存分配来为数组分配足够的空间。

    c 复制代码
    struct Data {
        int* numbers;
        int size;
    };
  3. 动态创建结构体数组: 如果你需要在运行时确定结构体数组的大小,你可以使用动态内存分配来创建一个结构体数组。

    c 复制代码
    struct Point {
        int x;
        int y;
    };
    
    struct Point* pointsArray = (struct Point*)malloc(numPoints * sizeof(struct Point));

在这些情况下,动态分配内存空间是很有用的,因为它允许你在运行时根据需要分配内存,而不需要提前知道数据的大小。然而,使用动态内存分配需要谨慎,确保在适当的时候释放内存,以避免内存泄漏。如果在程序中频繁使用动态分配内存,建议在代码中加入必要的内存管理策略,以确保内存的正确分配和释放。

相关推荐
YGGP16 分钟前
吃透 Golang 基础:数据结构之 Map
开发语言·数据结构·golang
BUG收容所所长21 分钟前
二分查找的「左右为难」:如何优雅地找到数组中元素的首尾位置
前端·javascript·算法
weixin_4196583144 分钟前
数据结构之栈
数据结构
图先1 小时前
数据结构第一章
数据结构
itsuifengerxing1 小时前
python 自定义无符号右移
算法
猎板PCB厚铜专家大族1 小时前
高频 PCB 技术发展趋势与应用解析
人工智能·算法·设计规范
dying_man2 小时前
LeetCode--24.两两交换链表中的结点
算法·leetcode
yours_Gabriel2 小时前
【力扣】2434.使用机器人打印字典序最小的字符串
算法·leetcode·贪心算法
草莓熊Lotso2 小时前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM3 小时前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法