爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      动态内存深钻研,管理机制精析完

      首页 知识中心 存储 文章详情页

      动态内存深钻研,管理机制精析完

      2025-03-05 09:10:48 阅读次数:9

      free,内存,函数,数组

      一、 为什么要有动态内存分配

      我们已经掌握的内存开辟⽅式有:
       
      int val = 20;//在栈空间上开辟四个字节
      char arr[10] = {0};//在栈空间上开辟10个字节的连续空间
      但是上述的开辟空间的⽅式有两个特点:
      • 空间开辟⼤⼩是固定的。
      • 数组在申明的时候,必须指定数组的⻓度,数组空间⼀旦确定了⼤⼩不能调整 但是对于空间的需求,不仅仅是上述的情况。有时候我们需要的空间⼤⼩在程序运⾏的时候才能知 道,那数组的编译时开辟空间的⽅式就不能满⾜了。
      C语⾔引⼊了动态内存开辟,让程序员⾃⼰可以申请和释放空间,就⽐较灵活了。
       
       

       二、malloc和free

      1、malloc

      C语⾔提供了⼀个动态内存开辟的函数:
       
      void* malloc (size_t size);
      这个函数向内存申请⼀块连续可⽤的空间,并返回指向这块空间的指针。
       
      • 如果开辟成功,则返回⼀个指向开辟好空间的指针。

      • 如果开辟失败,则返回⼀个 NULL 指针,因此malloc的返回值⼀定要做检查。

      • 返回值的类型是 void* ,所以malloc函数并不知道开辟空间的类型,具体在使⽤的时候使⽤者⾃⼰来决定。

      • 如果参数 size 为0,malloc的⾏为是标准是未定义的,取决于编译器。


      2、free

      C语⾔提供了另外⼀个函数free,专⻔是⽤来做动态内存的释放和回收的,函数原型如下:
       
      void free (void* ptr);
      free函数⽤来释放动态开辟的内存。
      • 如果参数 ptr 指向的空间不是动态开辟的,那free函数的⾏为是未定义的。
      • 如果参数 ptr 是NULL指针,则函数什么事都不做。
      • malloc和free都声明在 stdlib.h 头⽂件中。
       
      举个例⼦:
       
      #include <stdio.h>
      #include <stdlib.h>
      int main()
      {
      	int num = 0;
      	scanf("%d", &num);
      	int arr[num] = { 0 };
      	int* ptr = NULL;
      	ptr = (int*)malloc(num * sizeof(int));
      	
      		if (NULL != ptr)//判断ptr指针是否为空
      		{
      			int i = 0;
      			for (i = 0; i < num; i++)
      			{
      				*(ptr + i) = 0;
      			}
      		}
      	free(ptr);//释放ptr所指向的动态内存
      	ptr = NULL;//是否有必要?
      	return 0;
      }

      三、calloc和realloc

      1、calloc

      C语⾔还提供了⼀个函数叫 calloc , calloc 函数也⽤来动态内存分配。原型如下:
       
      void* calloc (size_t num, size_t size);
      • 函数的功能是为 num 个⼤⼩为 size 的元素开辟⼀块空间,并且把空间的每个字节初始化为0。
      • 与函数 malloc 的区别只在于 calloc 会在返回地址之前把申请的空间的每个字节初始化为全 0。
      举个例⼦:
      #include <stdio.h>
      #include <stdlib.h>
      int main()
      {
      	int* p = (int*)calloc(10, sizeof(int));
      	if (NULL != p)
      	{
      		int i = 0;
      		for (i = 0; i < 10; i++)
      		{
      			printf("%d ", *(p + i));
      		}
      	}
      	free(p);
      
      	p = NULL;
      	return 0;
      }
      输出结果:
       
      0 0 0 0 0 0 0 0 0 0
      所以如果我们对申请的内存空间的内容要求初始化,那么可以很⽅便的使⽤calloc函数来完成任务。

      2、realloc

      • realloc函数的出现让动态内存管理更加灵活。
      • 有时会我们发现过去申请的空间太⼩了,有时候我们⼜会觉得申请的空间过⼤了,那为了合理的使 ⽤内存,我们⼀定会对内存的⼤⼩做灵活的调整。那 realloc 函数就可以做到对动态开辟内存⼤⼩的调整。
      函数原型如下:
       
      void* realloc (void* ptr, size_t size);
      • ptr 是要调整的内存地址

      • size 调整之后新⼤⼩

      • 返回值为调整之后的内存起始位置。

      • 这个函数调整原内存空间⼤⼩的基础上,还会将原来内存中的数据移动到 新 的空间。

      • realloc在调整内存空间的是存在两种情况:

      • 情况1:原有空间之后有⾜够⼤的空间

      • 情况2:原有空间之后没有⾜够⼤的空间

       动态内存深钻研,管理机制精析完

      情况1

      当是情况1 的时候,要扩展内存就直接原有内存之后直接追加空间,原来空间的数据不发⽣变化。

      情况2

      当是情况2 的时候,原有空间之后没有⾜够多的空间时,扩展的⽅法是:在堆空间上另找⼀个合适⼤⼩的连续空间来使⽤。这样函数返回的是⼀个新的内存地址。

      由于上述的两种情况,realloc函数的使⽤就要注意⼀些。

      #include <stdio.h>
      #include <stdlib.h>
      int main()
      {
      	int* ptr = (int*)malloc(100);
      	if (ptr != NULL)
      	{
      		//业务处理
      	}
      	else
      	{
      		return 1;
      	}
      	//扩展容量
      	//代码1 - 直接将realloc的返回值放到ptr中
      	ptr = (int*)realloc(ptr, 1000);//这样可以吗?(如果申请失败会如何?)
      	//代码2 - 先将realloc函数的返回值放在p中,不为NULL,在放ptr中
      	int* p = NULL;
      	p = realloc(ptr, 1000);
      	if (p != NULL)
      
      	{
      		ptr = p;
      	}
      	//业务处理
      	free(ptr);
      	return 0;
      }

      四、常⻅的动态内存的错误

      1、对NULL指针的解引⽤操作

      #include <climits>
      void test()
      {
      	int* p = (int*)malloc(INT_MAX / 4);
      	*p = 20;//如果p的值是NULL,就会有问题
      	free(p);
      }
      

      2、对动态开辟空间的越界访问

      #include <cstddef>
      #include <cstdlib>
      void test()
      {
      	int i = 0;
      	int* p = (int*)malloc(10 * sizeof(int));
      	if (NULL == p)
      	{
      		exit(EXIT_FAILURE);
      	}
      	for (i = 0; i <= 10; i++)
      	{
      		*(p + i) = i;//当i是10的时候越界访问
      	}
      	free(p);
      }

      3、对⾮动态开辟内存使⽤free释放

      void test()
      
      {
      int a = 10;
      int* p = &a;
      free(p);//ok?
      }

      4、使⽤free释放⼀块动态开辟内存的⼀部分

      void test()
      {
      int *p = (int *)malloc(100);
      p++;
      free(p);//p不再指向动态内存的起始位置
      }

      5、对同⼀块动态内存多次释放

      void test()
      {
      	int* p = (int*)malloc(100);
      	free(p);
      	free(p);//重复释放
      }

      6、动态开辟内存忘记释放(内存泄漏)

      #include <cstddef>
      void test()
      {
      	int* p = (int*)malloc(100);
      	if (NULL != p)
      	{
      		*p = 20;
      	}
      }
      int main()
      {
      	test();
      	while (1);
      }
      

      忘记释放不再使⽤的动态开辟的空间会造成内存泄漏。

      切记:动态开辟的空间⼀定要释放,并且正确释放。


      五、动态内存经典笔试题分析

      1、 题⽬1:

      #include <cstddef>
      void GetMemory(char* p)
      {
      	p = (char*)malloc(100);
      }
      void Test(void)
      {
      	char* str = NULL;
      	GetMemory(str);
      	strcpy(str, "hello world");
      	printf(str);
      }
      请问运⾏Test 函数会有什么样的结果?

       

      2、 题⽬2:

      #include <cstddef>
      char* GetMemory(void)
      {
      	char p[] = "hello world";
      	return p;
      }
      void Test(void)
      {
      	char* str = NULL;
      	str = GetMemory();
      	printf(str);
      }
      请问运⾏Test 函数会有什么样的结果?

       

      3、题⽬3:

      #include <cstddef>
      void GetMemory(char** p, int num)
      {
      	*p = (char*)malloc(num);
      }
      void Test(void)
      {
      	char* str = NULL;
      	GetMemory(&str, 100);
      	strcpy(str, "hello");
      	printf(str);
      }

      请问运⾏Test 函数会有什么样的结果?
       

      4、 题⽬4:

      #include <cstddef>
      void Test(void)
      {
      	char* str = (char*)malloc(100);
      	strcpy(str, "hello");
      	free(str);
      	if (str != NULL)
      	{
      		strcpy(str, "world");
      		printf(str);
      	}
      }
      

      请问运⾏Test 函数会有什么样的结果?

       

      六、柔性数组

      也许你从来没有听说过柔性数组(flexible array)这个概念,但是它确实是存在的。

      C99 中,结构中的最后⼀个元素允许是未知⼤⼩的数组,这就叫做『柔性数组』成员。

      例如:
      struct st_type
      {
      	int i;
      
      	int a[0];//柔性数组成员
      };
      有些编译器会报错⽆法编译可以改成:
       
      struct st_type
      {
      	int i;
      	int a[];//柔性数组成员
      };

      1、柔性数组的特点:

      • 结构中的柔性数组成员前⾯必须⾄少⼀个其他成员。
      • sizeof 返回的这种结构⼤⼩不包括柔性数组的内存。
      • 包含柔性数组成员的结构⽤malloc ()函数进⾏内存的动态分配,并且分配的内存应该⼤于结构的⼤⼩,以适应柔性数组的预期⼤⼩。

      例如:

      typedef struct st_type
      {
      	int i;
      	int a[0];//柔性数组成员
      }type_a;
      int main()
      {
      	printf("%d\n", sizeof(type_a));//输出的是4
      	return 0;
      }

       


      2、柔性数组的使⽤

      //代码1
      #include <stdio.h>
      #include <stdlib.h>
      int main()
      {
      	int i = 0;
      	type_a* p = (type_a*);malloc(sizeof(type_a) + 100 * sizeof(int));
      	//业务处理
      	p->i = 100;
      	for (i = 0; i < 100; i++)
      	{
      		p->a[i] = i;
      	}
      	free(p);
      	return 0;
      }
      
      这样柔性数组成员a,相当于获得了100个整型元素的连续空间。

      3、柔性数组的优势

      上述的 type_a 结构也可以设计为下⾯的结构,也能完成同样的效果。
       
      //代码2
      #include <stdio.h>
      #include <stdlib.h>
      typedef struct st_type
      {
      	int i;
      	int* p_a;
      }type_a;
      int main()
      {
      	type_a* p = (type_a*)malloc(sizeof(type_a));
      	p->i = 100;
      	p->p_a = (int*)malloc(p->i * sizeof(int));
      	//业务处理
      	for (i = 0; i < 100; i++)
      	{
      		p->p_a[i] = i;
      	}
      	//释放空间
      	free(p->p_a);
      	p->p_a = NULL;
      	free(p);
      	p = NULL;
      	return 0;
      }
      上述 代码 1 和 代码 2 可以完成同样的功能,但是 ⽅法 1 的实现有两个好处:
       

      第⼀个好处是:⽅便内存释放

      如果我们的代码是在⼀个给别⼈⽤的函数中,你在⾥⾯做了⼆次内存分配,并把整个结构体返回给⽤⼾。⽤⼾调⽤free可以释放结构体,但是⽤⼾并不知道这个结构体内的成员也需要free,所以你不能指望⽤⼾来发现这个事。所以,如果我们把结构体的内存以及其成员要的内存⼀次性分配好了,并返回给⽤⼾⼀个结构体指针,⽤⼾做⼀次free就可以把所有的内存也给释放掉。

      第⼆个好处是:这样有利于访问速度.

      连续的内存有益于提⾼访问速度,也有益于减少内存碎⽚。(其实,我个⼈觉得也没多⾼了,反正你跑不了要⽤做偏移量的加法来寻址)

       扩展阅读:

      C语⾔结构体⾥的数组和指针

      七、总结C/C++中程序内存区域划分

      动态内存深钻研,管理机制精析完

      C/C++程序内存分配的⼏个区域:
      1. 栈区(stack):在执⾏函数时,函数内局部变量的存储单元都可以在栈上创建,函数执⾏结束时这些存储单元⾃动被释放。栈内存分配运算内置于处理器的指令集中,效率很⾼,但是分配的内存容量有限。 栈区主要存放运⾏函数⽽分配的局部变量、函数参数、返回数据、返回地址等。《函数栈帧的创建和销毁》
      2. 堆区(heap):⼀般由程序员分配释放, 若程序员不释放,程序结束时可能由OS(操作系统)回收 。分配⽅式类似于链表。
      3. 数据段(静态区):(static)存放全局变量、静态数据。程序结束后由系统释放。
      4. 代码段:存放函数体(类成员函数和全局函数)的⼆进制代码。

       八、总结

      1. 为什么要有动态内存分配:
      动态内存分配允许程序在运行时根据需要来分配和释放内存空间。这对于处理不确定大小的数据或者需要灵活地管理内存的情况非常重要。动态内存分配也可以避免静态内存分配的限制,使程序更具灵活性和扩展性。

      2. malloc和free:
      malloc函数用于分配指定大小的内存空间,并返回一个指向该内存块的指针。free函数用于释放之前通过malloc函数分配的内存空间,以供后续的内存分配使用。

      3. calloc和realloc:
      calloc函数用于分配指定大小的内存空间,并将内存块中的每个字节都初始化为0。realloc函数用于重新分配之前通过malloc或calloc函数分配的内存空间,允许扩大或缩小内存块的大小。

      4. 常见的动态内存的错误:
      - 内存泄漏:未释放通过动态内存分配获得的内存空间,导致内存资源的浪费。
      - 野指针:指向已释放的内存空间或未初始化的内存空间,访问这样的指针可能导致未定义的行为。
      - 内存越界:对数组或指针进行越界访问,可能导致数据损坏或程序崩溃。
      - 重复释放:多次释放同一块内存空间,也可能导致未定义的行为。

      5. 动态内存经典笔试题分析:
      动态内存经典笔试题通常涉及内存分配、释放和使用的各种细节。例如,常见的题目包括:内存泄漏的检测、内存越界的问题、realloc函数的使用、多维数组和指针的关系等。

      6. 柔性数组:
      柔性数组是C语言中的一种特殊用法,允许在结构体中定义一个具有可变长度的数组,可以通过动态内存分配来灵活地管理数组的大小。

      7. 总结C/C++中程序内存区域划分:
      在C/C++程序中,通常将程序的内存划分为以下几个区域:
      - 栈区:用于存放局部变量和函数调用的上下文信息。
      - 堆区:用于动态内存分配,由程序员手动管理内存的分配和释放。
      - 全局区/静态区:用于存储全局变量和静态变量。
      - 常量区:用于存放常量数据。
      - 代码区:用于存放程序的指令代码。

      总结以上内容:
      动态内存分配是一个重要的概念,它在程序中的灵活性和扩展性方面扮演着重要的角色。掌握动态内存分配的相关知识和技巧,可以帮助我们避免内存相关的错误和提高程序的效率。

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://long-lasting-dream.blog.csdn.net/article/details/145453738,作者:长久的梦,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:MYSQL中的数据类型(如果想知道MYSQL中有关数据类型的知识,那么只看这一篇就足够了!)

      下一篇:自定类型初登场,结构体中绽光芒

      相关文章

      2025-05-19 09:04:44

      js小题2:构造函数介绍与普通函数对比

      js小题2:构造函数介绍与普通函数对比

      2025-05-19 09:04:44
      new , 关键字 , 函数 , 对象 , 构造函数
      2025-05-19 09:04:30

      【Canvas技法】辐射式多道光影的实现

      【Canvas技法】辐射式多道光影的实现

      2025-05-19 09:04:30
      代码 , 函数 , 实现
      2025-05-19 09:04:22

      外设驱动库开发笔记54:外设库驱动设计改进的思考

      外设驱动库开发笔记54:外设库驱动设计改进的思考

      2025-05-19 09:04:22
      使用 , 函数 , 初始化 , 定义 , 对象
      2025-05-19 09:04:14

      C语言字符函数和字符串函数--(超全超详细)

      C语言字符函数和字符串函数--(超全超详细)

      2025-05-19 09:04:14
      函数 , 字符 , 字符串
      2025-05-19 09:04:14

      复杂度的OJ练习

      复杂度的OJ练习

      2025-05-19 09:04:14
      代码 , 复杂度 , 思路 , 数组 , 算法
      2025-05-16 09:15:24

      如何将一串数字用函数的方法倒过来(C语言)

      如何将一串数字用函数的方法倒过来(C语言)

      2025-05-16 09:15:24
      函数 , 数字 , 数组
      2025-05-16 09:15:24

      jQuery遍历对象、数组、集合

      jQuery遍历对象、数组、集合

      2025-05-16 09:15:24
      jQuery , 对象 , 数组 , 遍历 , 集合
      2025-05-16 09:15:17

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      递归,搜索,回溯算法(3)之穷举,暴搜,深搜,回溯,剪枝

      2025-05-16 09:15:17
      回溯 , 子集 , 数组 , 算法 , 递归
      2025-05-14 10:33:31

      【数据结构】第一章——绪论(2)

      【数据结构】第一章——绪论(2)

      2025-05-14 10:33:31
      函数 , 实现 , 打印 , 理解 , 算法 , 输入 , 输出
      2025-05-14 10:33:31

      计算机小白的成长历程——数组(1)

      计算机小白的成长历程——数组(1)

      2025-05-14 10:33:31
      strlen , 个数 , 元素 , 内存 , 十六进制 , 地址 , 数组
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5239955

      查看更多

      最新文章

      30天拿下Rust之所有权

      2025-05-14 10:07:38

      Linux top 命令使用教程

      2025-05-14 10:02:58

      java循环创建对象内存溢出怎么解决

      2025-05-14 09:51:15

      mysql 存储函数及调用

      2025-05-13 09:53:13

      m3db调优踩坑问题总结

      2025-05-08 09:03:57

      Redis多级缓存指南:从前端到后端全方位优化!

      2025-04-15 09:24:56

      查看更多

      热门文章

      获取服务器CPU、内存等各类信息工具类

      2023-04-27 08:00:25

      linux的存储管理

      2023-03-14 11:10:02

      libcurl第十二课 内存分析

      2023-03-15 09:25:34

      存储过程数组实现

      2023-05-08 09:59:10

      JS 变量、作用域与内存

      2023-05-19 03:35:34

      Confluence 7 如何修改启动内存

      2023-05-31 08:47:59

      查看更多

      热门标签

      存储 缓存 内存 数据库 数据 redis mysql 服务器 数据恢复 Redis linux java 链表 MySQL sql
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      洞察异常的本质-记一次异常排查

      学习随机_4

      全面理解JMM模型

      用Radeon RAMDisk在Windows 10中创建关机或重启不消失的内存虚拟盘

      redis优点及场景

      如何在Ubuntu中查看内存使用情况?

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号