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));

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

相关推荐
金融小师妹1 小时前
应用BERT-GCN跨模态情绪分析:贸易缓和与金价波动的AI归因
大数据·人工智能·算法
广州智造1 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
belldeep3 小时前
如何阅读、学习 Tcc (Tiny C Compiler) 源代码?如何解析 Tcc 源代码?
c语言·开发语言
Trent19853 小时前
影楼精修-肤色统一算法解析
图像处理·人工智能·算法·计算机视觉
feifeigo1233 小时前
高光谱遥感图像处理之数据分类的fcm算法
图像处理·算法·分类
北上ing4 小时前
算法练习:19.JZ29 顺时针打印矩阵
算法·leetcode·矩阵
.格子衫.6 小时前
真题卷001——算法备赛
算法
XiaoyaoCarter6 小时前
每日一道leetcode
c++·算法·leetcode·职场和发展·二分查找·深度优先·前缀树
Hygge-star6 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
June`7 小时前
专题二:二叉树的深度搜索(二叉树剪枝)
c++·算法·深度优先·剪枝