王道训练营课时6-作业2

该程序示例演示了如何在C语言中使用`malloc`函数动态分配内存,然后利用`fgets`安全地读取用户输入的字符串。输入一个整数n作为内存大小,程序避免了`gets`函数的安全问题,确保不会发生缓冲区溢出。
摘要由CSDN通过智能技术生成
/*输入一个整数,然后申请对应大小空间内存,然后读取一个字符串,字符串的输入长度小于最初的输入的整数大小,最后输出输入的字符串即可 涉及到malloc函数的使用,在考研初试中出现的概率较高*/

#include<stdio.h>
#include<stdlib.h>
#pragma warning(disable:4996)

int main()
{
	int n;//代表申请空间大小

	scanf("%d", &n);//读取
	char c;
	scanf("%c", &c);//清除标准缓冲区中的\n
	char *p;
	p = (char*)malloc(n);//申请n个字节大小的空间,强制类型转换char*
	fgets(p,n,stdin);//可以使用fgets(p,n,stdin) gets被去掉是因为不安全,会访问越界
	puts(p);


	return 0;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值