爆款云主机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云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      【装饰器】详解Python的装饰器--为已经存在的函数或对象添加额外的功能

      首页 知识中心 软件开发 文章详情页

      【装饰器】详解Python的装饰器--为已经存在的函数或对象添加额外的功能

      2025-03-05 09:23:32 阅读次数:11

      函数,参数,对象,装饰,返回

      装饰器作用:给已经存在的函数增加额外功能。(根据开闭原则,增加功能应该是以扩展的方式而不是修改的方式--》扩展)

      最简单的装饰器:

      原来函数:func

      想给函数添加额外功能,则用一个"装饰函数"wrapper将额外的功能和func包在一起,然后返回打包后的函数,就完成了对函数的装饰扩展。

      def debug(func):
          def wrapper():
      
              #增加一些额外的功能
              #……
              print "[DEBUG]: enter {}()".format(func.__name__)
              #……
              return func() #做完了额外的,执行func----相当于加了装饰器func多了这些额外的功能
          return wrapper
       
      @debug
      def say_hello():
          print "hello!"
      

      带一个参数的装饰器:

      指定装饰器函数wrapper接受和原函数一样的参数即可,比如:

      def debug(func):
          def wrapper(something):  # 指定一毛一样的参数
              print "[DEBUG]: enter {}()".format(func.__name__)
              return func(something)
          return wrapper  # 返回包装过函数
       
      @debug
      def say(something):
          print "hello {}!".format(something)

      不定个数参数则需要了解:*arg 和**kwarg 即可

      这是最简单的装饰器,但是有一个问题,如果被装饰的函数需要传入参数,那么这个装饰器就坏了。因为返回的函数并不能接受参数,你可以指定装饰器函数wrapper接受和原函数一样的参数,比如:

      def debug(func):
          def wrapper(something):  # 指定一毛一样的参数
              print "[DEBUG]: enter {}()".format(func.__name__)
              return func(something)
          return wrapper  # 返回包装过函数
      
      @debug
      def say(something):
          print "hello {}!".format(something)

      这样你就解决了一个问题,但又多了N个问题。因为函数有千千万,你只管你自己的函数,别人的函数参数是什么样子,鬼知道?还好Python提供了可变参数*args和关键字参数**kwargs (去复习*args和**kwargs),有了这两个参数,装饰器就可以用于任意目标函数了。

      def debug(func):
          def wrapper(*args, **kwargs):  # 指定宇宙无敌参数
              print "[DEBUG]: enter {}()".format(func.__name__)
              print 'Prepare and say...',
              return func(*args, **kwargs)
          return wrapper  # 返回
      
      @debug
      def say(something):
          print "hello {}!".format(something)

      至此,你已完全掌握初级的装饰器写法。

      高级一点的装饰器

      带参数的装饰器和类装饰器属于进阶的内容。在理解这些装饰器之前,最好对函数的闭包和装饰器的接口约定有一定了解。

      带参数的装饰器

      假设我们前文的装饰器需要完成的功能不仅仅是能在进入某个函数后打出log信息,而且还需指定log的级别,那么装饰器就会是这样的。

      def logging(level):
          def wrapper(func):
              def inner_wrapper(*args, **kwargs):
                  print "[{level}]: enter function {func}()".format(
                      level=level,
                      func=func.__name__)
                  return func(*args, **kwargs)
              return inner_wrapper
          return wrapper
      
      @logging(level='INFO')
      def say(something):
          print "say {}!".format(something)
      
      # 如果没有使用@语法,等同于
      # say = logging(level='INFO')(say)
      
      @logging(level='DEBUG')
      def do(something):
          print "do {}...".format(something)
      
      if __name__ == '__main__':
          say('hello')
          do("my work")

      是不是有一些晕?你可以这么理解,当带参数的装饰器被打在某个函数上时,比如@logging(level='DEBUG'),它其实是一个函数,会马上被执行,只要这个它返回的结果是一个装饰器时,那就没问题。细细再体会一下。

      基于类实现的装饰器

      装饰器函数其实是这样一个接口约束,它必须接受一个callable对象作为参数,然后返回一个callable对象。在Python中一般callable对象都是函数,但也有例外。只要某个对象重载了__call__()方法,那么这个对象就是callable的。

      class Test():
          def __call__(self):
              print 'call me!'
      
      t = Test()
      t()  # call me

      像__call__这样前后都带下划线的方法在Python中被称为内置方法,有时候也被称为魔法方法。重载这些魔法方法一般会改变对象的内部行为。上面这个例子就让一个类对象拥有了被调用的行为。

      回到装饰器上的概念上来,装饰器要求接受一个callable对象,并返回一个callable对象(不太严谨,详见后文)。那么用类来实现也是也可以的。我们可以让类的构造函数__init__()接受一个函数,然后重载__call__()并返回一个函数,也可以达到装饰器函数的效果。

      class logging(object):
          def __init__(self, func):
              self.func = func
      
          def __call__(self, *args, **kwargs):
              print "[DEBUG]: enter function {func}()".format(
                  func=self.func.__name__)
              return self.func(*args, **kwargs)
      @logging
      def say(something):
          print "say {}!".format(something)

      带参数的类装饰器

      如果需要通过类形式实现带参数的装饰器,那么会比前面的例子稍微复杂一点。那么在构造函数里接受的就不是一个函数,而是传入的参数。通过类把这些参数保存起来。然后在重载__call__方法是就需要接受一个函数并返回一个函数。

      class logging(object):
          def __init__(self, level='INFO'):
              self.level = level
              
          def __call__(self, func): # 接受函数
              def wrapper(*args, **kwargs):
                  print "[{level}]: enter function {func}()".format(
                      level=self.level,
                      func=func.__name__)
                  func(*args, **kwargs)
              return wrapper  #返回函数
      
      @logging(level='INFO')
      def say(something):
          print "say {}!".format(something)

      内置的装饰器

      内置的装饰器和普通的装饰器原理是一样的,只不过返回的不是函数,而是类对象,所以更难理解一些。

      @property

      在了解这个装饰器前,你需要知道在不使用装饰器怎么写一个属性。

      def getx(self):
          return self._x
      
      def setx(self, value):
          self._x = value
          
      def delx(self):
         del self._x
      
      # create a property
      x = property(getx, setx, delx, "I am doc for x property")

      以上就是一个Python属性的标准写法,其实和Java挺像的,但是太罗嗦。有了@语法糖,能达到一样的效果但看起来更简单。

      @property
      def x(self): ...
      
      # 等同于
      
      def x(self): ...
      x = property(x)

      属性有三个装饰器:setter, getter, deleter ,都是在property()的基础上做了一些封装,因为setter和deleter是property()的第二和第三个参数,不能直接套用@语法。getter装饰器和不带getter的属性装饰器效果是一样的,估计只是为了凑数,本身没有任何存在的意义。经过@property装饰过的函数返回的不再是一个函数,而是一个property对象。

      >>> property()
      <property object at 0x10ff07940>

      @staticmethod,@classmethod

      有了@property装饰器的了解,这两个装饰器的原理是差不多的。@staticmethod返回的是一个staticmethod类对象,而@classmethod返回的是一个classmethod类对象。他们都是调用的是各自的__init__()构造函数。

      class classmethod(object):
          """
          classmethod(function) -> method
          """    
          def __init__(self, function): # for @classmethod decorator
              pass
          # ...
      class staticmethod(object):
          """
          staticmethod(function) -> method
          """
          def __init__(self, function): # for @staticmethod decorator
              pass
          # ...

      装饰器的@语法就等同调用了这两个类的构造函数。

      class Foo(object):
      
          @staticmethod
          def bar():
              pass
          
          # 等同于 bar = staticmethod(bar)

      至此,我们上文提到的装饰器接口定义可以更加明确一些,装饰器必须接受一个callable对象,其实它并不关心你返回什么,可以是另外一个callable对象(大部分情况),也可以是其他类对象,比如property。

      装饰器里的那些坑

      装饰器可以让你代码更加优雅,减少重复,但也不全是优点,也会带来一些问题。

      位置错误的代码

      让我们直接看示例代码。

      def html_tags(tag_name):
          print 'begin outer function.'
          def wrapper_(func):
              print "begin of inner wrapper function."
              def wrapper(*args, **kwargs):
                  content = func(*args, **kwargs)
                  print "<{tag}>{content}</{tag}>".format(tag=tag_name, content=content)
              print 'end of inner wrapper function.'
              return wrapper
          print 'end of outer function'
          return wrapper_
      
      @html_tags('b')
      def hello(name='Toby'):
          return 'Hello {}!'.format(name)
      
      hello()
      hello()

      在装饰器中我在各个可能的位置都加上了print语句,用于记录被调用的情况。你知道他们最后打印出来的顺序吗?如果你心里没底,那么最好不要在装饰器函数之外添加逻辑功能,否则这个装饰器就不受你控制了。以下是输出结果:

      begin outer function.
      end of outer function
      begin of inner wrapper function.
      end of inner wrapper function.
      <b>Hello Toby!</b>
      <b>Hello Toby!</b>

      错误的函数签名和文档

      装饰器装饰过的函数看上去名字没变,其实已经变了。

      def logging(func):
          def wrapper(*args, **kwargs):
              """print log before a function."""
              print "[DEBUG] {}: enter {}()".format(datetime.now(), func.__name__)
              return func(*args, **kwargs)
          return wrapper
      
      @logging
      def say(something):
          """say something"""
          print "say {}!".format(something)
      
      print say.__name__  # wrapper

      为什么会这样呢?只要你想想装饰器的语法糖@代替的东西就明白了。@等同于这样的写法。

      say = logging(say)

      logging其实返回的函数名字刚好是wrapper,那么上面的这个语句刚好就是把这个结果赋值给say,say的__name__自然也就是wrapper了,不仅仅是name,其他属性也都是来自wrapper,比如doc,source等等。

      使用标准库里的functools.wraps,可以基本解决这个问题。

      from functools import wraps
      
      def logging(func):
          @wraps(func)
          def wrapper(*args, **kwargs):
              """print log before a function."""
              print "[DEBUG] {}: enter {}()".format(datetime.now(), func.__name__)
              return func(*args, **kwargs)
          return wrapper
      
      @logging
      def say(something):
          """say something"""
          print "say {}!".format(something)
      
      print say.__name__  # say
      print say.__doc__ # say something

      看上去不错!主要问题解决了,但其实还不太完美。因为函数的签名和源码还是拿不到的。

      import inspect
      print inspect.getargspec(say)  # failed
      print inspect.getsource(say)  # failed

      如果要彻底解决这个问题可以借用第三方包,比如wrapt。后文有介绍。

      不能装饰@staticmethod 或者 @classmethod

      当你想把装饰器用在一个静态方法或者类方法时,不好意思,报错了。

      class Car(object):
          def __init__(self, model):
              self.model = model
      
          @logging  # 装饰实例方法,OK
          def run(self):
              print "{} is running!".format(self.model)
      
          @logging  # 装饰静态方法,Failed
          @staticmethod
          def check_model_for(obj):
              if isinstance(obj, Car):
                  print "The model of your car is {}".format(obj.model)
              else:
                  print "{} is not a car!".format(obj)
      
      """
      Traceback (most recent call last):
      ...
        File "example_4.py", line 10, in logging
          @wraps(func)
        File "C:\Python27\lib\functools.py", line 33, in update_wrapper
          setattr(wrapper, attr, getattr(wrapped, attr))
      AttributeError: 'staticmethod' object has no attribute '__module__'
      """

      前面已经解释了@staticmethod这个装饰器,其实它返回的并不是一个callable对象,而是一个staticmethod对象,那么它是不符合装饰器要求的(比如传入一个callable对象),你自然不能在它之上再加别的装饰器。要解决这个问题很简单,只要把你的装饰器放在@staticmethod之前就好了,因为你的装饰器返回的还是一个正常的函数,然后再加上一个@staticmethod是不会出问题的。

      class Car(object):
          def __init__(self, model):
              self.model = model
      
          @staticmethod
          @logging  # 在@staticmethod之前装饰,OK
          def check_model_for(obj):
              pass

      如何优化你的装饰器

      嵌套的装饰函数不太直观,我们可以使用第三方包类改进这样的情况,让装饰器函数可读性更好。

      decorator.py

      decorator.py 是一个非常简单的装饰器加强包。你可以很直观的先定义包装函数wrapper(),再使用decorate(func, wrapper)方法就可以完成一个装饰器。

      from decorator import decorate
      
      def wrapper(func, *args, **kwargs):
          """print log before a function."""
          print "[DEBUG] {}: enter {}()".format(datetime.now(), func.__name__)
          return func(*args, **kwargs)
      
      def logging(func):
          return decorate(func, wrapper)  # 用wrapper装饰func

      你也可以使用它自带的@decorator装饰器来完成你的装饰器。

      from decorator import decorator
      
      @decorator
      def logging(func, *args, **kwargs):
          print "[DEBUG] {}: enter {}()".format(datetime.now(), func.__name__)
          return func(*args, **kwargs)

      decorator.py实现的装饰器能完整保留原函数的name,doc和args,唯一有问题的就是inspect.getsource(func)返回的还是装饰器的源代码,你需要改成inspect.getsource(func.__wrapped__)。

      wrapt

      wrapt是一个功能非常完善的包,用于实现各种你想到或者你没想到的装饰器。使用wrapt实现的装饰器你不需要担心之前inspect中遇到的所有问题,因为它都帮你处理了,甚至inspect.getsource(func)也准确无误。

      import wrapt
      
      # without argument in decorator
      @wrapt.decorator
      def logging(wrapped, instance, args, kwargs):  # instance is must
          print "[DEBUG]: enter {}()".format(wrapped.__name__)
          return wrapped(*args, **kwargs)
      
      @logging
      def say(something): pass

      使用wrapt你只需要定义一个装饰器函数,但是函数签名是固定的,必须是(wrapped, instance, args, kwargs),注意第二个参数instance是必须的,就算你不用它。当装饰器装饰在不同位置时它将得到不同的值,比如装饰在类实例方法时你可以拿到这个类实例。根据instance的值你能够更加灵活的调整你的装饰器。另外,args和kwargs也是固定的,注意前面没有星号。在装饰器内部调用原函数时才带星号。

      如果你需要使用wrapt写一个带参数的装饰器,可以这样写。

      def logging(level):
          @wrapt.decorator
          def wrapper(wrapped, instance, args, kwargs):
              print "[{}]: enter {}()".format(level, wrapped.__name__)
              return wrapped(*args, **kwargs)
          return wrapper
      
      @logging(level="INFO")
      def do(work): pass

      小结

      Python的装饰器和Java的注解(Annotation)并不是同一回事,和C#中的特性(Attribute)也不一样,完全是两个概念。

      装饰器的理念是对原函数、对象的加强,相当于重新封装,所以一般装饰器函数都被命名为wrapper(),意义在于包装。函数只有在被调用时才会发挥其作用。比如@logging装饰器可以在函数执行时额外输出日志,@cache装饰过的函数可以缓存计算结果等等。

      而注解和特性则是对目标函数或对象添加一些属性,相当于将其分类。这些属性可以通过反射拿到,在程序运行时对不同的特性函数或对象加以干预。比如带有Setup的函数就当成准备步骤执行,或者找到所有带有TestMethod的函数依次执行等等。

      至此我所了解的装饰器已经讲完,但是还有一些内容没有提到,比如装饰类的装饰器。有机会再补充。谢谢观看。

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

      上一篇:编程工具的选择对开发者效率的影响:一项数据驱动的探讨

      下一篇:【Python】RSA算法实现的原理和过程(附源码)

      相关文章

      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:22

      外设驱动库开发笔记46:MAX31855热偶变送器驱动

      外设驱动库开发笔记46:MAX31855热偶变送器驱动

      2025-05-19 09:04:22
      对象 , 温度
      2025-05-19 09:04:14

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

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

      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:24

      模拟实现strcmp

      模拟实现strcmp

      2025-05-16 09:15:24
      gcc , 编译器 , 返回
      2025-05-14 10:33:31

      计算机初级选手的成长历程——操作符详解(2)

      计算机初级选手的成长历程——操作符详解(2)

      2025-05-14 10:33:31
      对象 , 操作 , 操作符 , 表达式 , 运算 , 逗号 , 逻辑
      2025-05-14 10:33:31

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

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

      2025-05-14 10:33:31
      函数 , 实现 , 打印 , 理解 , 算法 , 输入 , 输出
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5236958

      查看更多

      最新文章

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

      2025-05-19 09:04:30

      外设驱动库开发笔记46:MAX31855热偶变送器驱动

      2025-05-19 09:04:22

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

      2025-05-19 09:04:22

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

      2025-05-19 09:04:14

      模拟实现strcmp

      2025-05-16 09:15:24

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

      2025-05-16 09:15:24

      查看更多

      热门文章

      游戏编程之十一 图像页CPICPAGE介绍

      2022-11-28 01:25:04

      Python 函数调用父类详解

      2023-04-23 09:44:31

      C#8.0新语法

      2023-02-07 10:34:04

      游戏编程之六 游戏编程的特点

      2024-09-25 10:13:46

      实现远程线程DLL注入

      2023-05-04 08:57:15

      Python----map,filter,reduce,zip,lambda的使用方法

      2023-04-28 02:17:08

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

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

      天翼云电脑(公众版)

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

      对象存储

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

      云硬盘

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

      查看更多

      随机文章

      ffmpeg音视频开发从入门到精通——常用结构体介绍(一)

      元编程:C++递归模板,使类的静态成员函数达到虚函数的效果。

      【软件质量】用profile 工具查找软件性能瓶颈|性能

      synchronized 经典问题之“线程八锁”

      java跳动爱心代码

      java之序列化与反序列化的详细解析(全)

      • 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号