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

      如何对 React 函数式组件进行优化

      首页 知识中心 其他 文章详情页

      如何对 React 函数式组件进行优化

      2024-12-18 08:28:21 阅读次数:18

      props,React,函数,渲染,组件

      前言

      目的

      本文只介绍函数式组件特有的性能优化方式,类组件和函数式组件都有的不介绍,比如 key 的使用。另外本文不详细的介绍 API 的使用,后面也许会写,其实想用好 hooks 还是蛮难的。

      面向读者

      有过 React 函数式组件的实践,并且对 hooks 有过实践,对 useState、useCallback、useMemo API 至少看过文档,如果你有过对类组件的性能优化经历,那么这篇文章会让你有种熟悉的感觉。

      React 性能优化思路

      我觉得React 性能优化的理念的主要方向就是这两个:

      1. 减少重新 render 的次数。因为在 React 里最重(花时间最长)的一块就是 reconction(简单的可以理解为 diff),如果不 render,就不会 reconction。
      2. 减少计算的量。主要是减少重复计算,对于函数式组件来说,每次 render 都会重新从头开始执行函数调用。

      在使用类组件的时候,使用的 React 优化 API 主要是:shouldComponentUpdate和 PureComponent,这两个 API 所提供的解决思路都是为了减少重新 render 的次数,主要是减少父组件更新而子组件也更新的情况,虽然也可以在 state 更新的时候阻止当前组件渲染,如果要这么做的话,证明你这个属性不适合作为 state,而应该作为静态属性或者放在 class 外面作为一个简单的变量 。

      但是在函数式组件里面没有声明周期也没有类,那如何来做性能优化呢?

      React.memo

      首先要介绍的就是 React.memo,这个 API 可以说是对标类组件里面的 PureComponent,这是可以减少重新 render 的次数的。

      可能产生性能问题的例子

      举个🌰,首先我们看两段代码:

      在根目录有一个 index.js,代码如下,实现的东西大概就是:上面一个 title,中间一个 button(点击 button 修改 title),下面一个木偶组件,传递一个 name 进去。

      // index.js
      import React, { useState } from "react";
      import ReactDOM from "react-dom";
      import Child from './child'
      
      function App() {
        const [title, setTitle] = useState("这是一个 title")
      
        return (
          <div className="App">
            <h1>{ title }</h1>
            <button onClick={() => setTitle("title 已经改变")}>改名字</button>
            <Child name="桃桃"></Child>
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);
      
      // index.js
      import React, { useState } from "react";
      import ReactDOM from "react-dom";
      import Child from './child'
      
      function App() {
        const [title, setTitle] = useState("这是一个 title")
      
        return (
          <div className="App">
            <h1>{ title }</h1>
            <button onClick={() => setTitle("title 已经改变")}>改名字</button>
            <Child name="桃桃"></Child>
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);

      在同级目录有一个 child.js

      // child.js
      import React from "react";
      
      function Child(props) {
        console.log()
        return <h1>{}</h1>
      }
      
      export default Child
      // child.js
      import React from "react";
      
      function Child(props) {
        console.log()
        return <h1>{}</h1>
      }
      
      export default Child

      当首次渲染的时候的效果如下:

      并且控制台会打印"桃桃”,证明 Child 组件渲染了。

      接下来点击改名字这个 button,页面会变成:

      title 已经改变了,而且控制台也打印出"桃桃",可以看到虽然我们改的是父组件的状态,父组件重新渲染了,并且子组件也重新渲染了。你可能会想,传递给 Child 组件的 props 没有变,要是 Child 组件不重新渲染就好了,为什么会这么想呢?

      我们假设 Child 组件是一个非常大的组件,渲染一次会消耗很多的性能,那么我们就应该尽量减少这个组件的渲染,否则就容易产生性能问题,所以子组件如果在 props 没有变化的情况下,就算父组件重新渲染了,子组件也不应该渲染。

      那么我们怎么才能做到在 props 没有变化的时候,子组件不渲染呢?

      答案就是用 React.memo 在给定相同 props 的情况下渲染相同的结果,并且通过记忆组件渲染结果的方式来提高组件的性能表现。

      React.memo 的基础用法

      把声明的组件通过React.memo包一层就好了,React.memo其实是一个高阶函数,传递一个组件进去,返回一个可以记忆的组件。

      function Component(props) {
         /* 使用 props 渲染 */
      }
      const MyComponent = React.memo(Component);
      function Component(props) {
         /* 使用 props 渲染 */
      }
      const MyComponent = React.memo(Component);

      那么上面例子的 Child 组件就可以改成这样:

      import React from "react";
      
      function Child(props) {
        console.log()
        return <h1>{}</h1>
      }
      
      export default React.memo(Child)
      import React from "react";
      
      function Child(props) {
        console.log()
        return <h1>{}</h1>
      }
      
      export default React.memo(Child)

      通过 React.memo 包裹的组件在 props 不变的情况下,这个被包裹的组件是不会重新渲染的,也就是说上面那个例子,在我点击改名字之后,仅仅是 title 会变,但是 Child 组件不会重新渲染(表现出来的效果就是 Child 里面的 log 不会在控制台打印出来),会直接复用最近一次渲染的结果。

      这个效果基本跟类组件里面的 PureComponent效果极其类似,只是前者用于函数组件,后者用于类组件。

      React.memo 高级用法

      默认情况下其只会对 props 的复杂对象做浅层对比(浅层对比就是只会对比前后两次 props 对象引用是否相同,不会对比对象里面的内容是否相同),如果你想要控制对比过程,那么请将自定义的比较函数通过第二个参数传入来实现。

      function MyComponent(props) {
        /* 使用 props 渲染 */
      }
      function areEqual(prevProps, nextProps) {
        /*
        如果把 nextProps 传入 render 方法的返回结果与
        将 prevProps 传入 render 方法的返回结果一致则返回 true,
        否则返回 false
        */
      }
      export default React.memo(MyComponent, areEqual);
      function MyComponent(props) {
        /* 使用 props 渲染 */
      }
      function areEqual(prevProps, nextProps) {
        /*
        如果把 nextProps 传入 render 方法的返回结果与
        将 prevProps 传入 render 方法的返回结果一致则返回 true,
        否则返回 false
        */
      }
      export default React.memo(MyComponent, areEqual);

      此部分来自于 React 官网。

      如果你有在类组件里面使用过 shouldComponentUpdate() 这个方法,你会对 React.memo 的第二个参数非常的熟悉,不过值得注意的是,如果 props 相等,areEqual 会返回 true;如果 props 不相等,则返回 false。这与 shouldComponentUpdate 方法的返回值相反。

      useCallback

      现在根据上面的例子,再改一下需求,在上面的需求上增加一个副标题,并且有一个修改副标题的 button,然后把修改标题的 button 放到 Child 组件里。

      把修改标题的 button 放到 Child 组件的目的是,将修改 title 的事件通过 props 传递给 Child 组件,然后观察这个事件可能会引起性能问题。

      首先看代码:

      父组件 index.js

      // index.js
      import React, { useState } from "react";
      import ReactDOM from "react-dom";
      import Child from "./child";
      
      function App() {
        const [title, setTitle] = useState("这是一个 title");
        const [subtitle, setSubtitle] = useState("我是一个副标题");
      
        const callback = () => {
          setTitle("标题改变了");
        };
        return (
          <div className="App">
            <h1>{title}</h1>
            <h2>{subtitle}</h2>
            <button onClick={() => setSubtitle("副标题改变了")}>改副标题</button>
            <Child onClick={callback} name="桃桃" />
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);
      
      // index.js
      import React, { useState } from "react";
      import ReactDOM from "react-dom";
      import Child from "./child";
      
      function App() {
        const [title, setTitle] = useState("这是一个 title");
        const [subtitle, setSubtitle] = useState("我是一个副标题");
      
        const callback = () => {
          setTitle("标题改变了");
        };
        return (
          <div className="App">
            <h1>{title}</h1>
            <h2>{subtitle}</h2>
            <button onClick={() => setSubtitle("副标题改变了")}>改副标题</button>
            <Child onClick={callback} name="桃桃" />
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);

      子组件 child.js

      import React from "react";
      
      function Child(props) {
        console.log(props);
        return (
          <>
            <button onClick={props.onClick}>改标题</button>
            <h1>{}</h1>
          </>
        );
      }
      
      export default React.memo(Child);
      import React from "react";
      
      function Child(props) {
        console.log(props);
        return (
          <>
            <button onClick={props.onClick}>改标题</button>
            <h1>{}</h1>
          </>
        );
      }
      
      export default React.memo(Child);

      首次渲染的效果

      这段代码在首次渲染的时候会显示上图的样子,并且控制台会打印出桃桃。

      然后当我点击改副标题这个 button 之后,副标题会变为「副标题改变了」,并且控制台会再次打印出桃桃,这就证明了子组件又重新渲染了,但是子组件没有任何变化,那么这次 Child 组件的重新渲染就是多余的,那么如何避免掉这个多余的渲染呢?

      找原因

      我们在解决问题的之前,首先要知道这个问题是什么原因导致的?

      咱们来分析,一个组件重新重新渲染,一般三种情况:

      1. 要么是组件自己的状态改变
      2. 要么是父组件重新渲染,导致子组件重新渲染,但是父组件的 props 没有改版
      3. 要么是父组件重新渲染,导致子组件重新渲染,但是父组件传递的 props 改变

      接下来用排除法查出是什么原因导致的:

      第一种很明显就排除了,当点击改副标题 的时候并没有去改变 Child 组件的状态;

      第二种情况好好想一下,是不是就是在介绍 React.memo 的时候情况,父组件重新渲染了,父组件传递给子组件的 props 没有改变,但是子组件重新渲染了,我们这个时候用 React.memo 来解决了这个问题,所以这种情况也排除。

      那么就是第三种情况了,当父组件重新渲染的时候,传递给子组件的 props 发生了改变,再看传递给 Child 组件的就两个属性,一个是 name,一个是 onClick ,name 是传递的常量,不会变,变的就是 onClick 了,为什么传递给 onClick 的 callback 函数会发生改变呢?在文章的开头就已经说过了,在函数式组件里每次重新渲染,函数组件都会重头开始重新执行,那么这两次创建的 callback 函数肯定发生了改变,所以导致了子组件重新渲染。

      如何解决

      找到问题的原因了,那么解决办法就是在函数没有改变的时候,重新渲染的时候保持两个函数的引用一致,这个时候就要用到 useCallback 这个 API 了。

      useCallback 使用方法
      const callback = () => {
        doSomething(a, b);
      }
      
      const memoizedCallback = useCallback(callback, [a, b])
      const callback = () => {
        doSomething(a, b);
      }
      
      const memoizedCallback = useCallback(callback, [a, b])

      把函数以及依赖项作为参数传入 useCallback,它将返回该回调函数的 memoized 版本,这个 memoizedCallback 只有在依赖项有变化的时候才会更新。

      那么可以将 index.js 修改为这样:

      // index.js
      import React, { useState, useCallback } from "react";
      import ReactDOM from "react-dom";
      import Child from "./child";
      
      function App() {
        const [title, setTitle] = useState("这是一个 title");
        const [subtitle, setSubtitle] = useState("我是一个副标题");
      
        const callback = () => {
          setTitle("标题改变了");
        };
      
        // 通过 useCallback 进行记忆 callback,并将记忆的 callback 传递给 Child
        const memoizedCallback = useCallback(callback, [])
        
        return (
          <div className="App">
            <h1>{title}</h1>
            <h2>{subtitle}</h2>
            <button onClick={() => setSubtitle("副标题改变了")}>改副标题</button>
            <Child onClick={memoizedCallback} name="桃桃" />
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);
      
      // index.js
      import React, { useState, useCallback } from "react";
      import ReactDOM from "react-dom";
      import Child from "./child";
      
      function App() {
        const [title, setTitle] = useState("这是一个 title");
        const [subtitle, setSubtitle] = useState("我是一个副标题");
      
        const callback = () => {
          setTitle("标题改变了");
        };
      
        // 通过 useCallback 进行记忆 callback,并将记忆的 callback 传递给 Child
        const memoizedCallback = useCallback(callback, [])
        
        return (
          <div className="App">
            <h1>{title}</h1>
            <h2>{subtitle}</h2>
            <button onClick={() => setSubtitle("副标题改变了")}>改副标题</button>
            <Child onClick={memoizedCallback} name="桃桃" />
          </div>
        );
      }
      
      const rootElement = document.getElementById("root");
      ReactDOM.render(<App />, rootElement);

      这样我们就可以看到只会在首次渲染的时候打印出桃桃,当点击改副标题和改标题的时候是不会打印桃桃的。

      如果我们的 callback 传递了参数,当参数变化的时候需要让它重新添加一个缓存,可以将参数放在 useCallback 第二个参数的数组中,作为依赖的形式,使用方式跟 useEffect 类似。

      useMemo

      在文章的开头就已经介绍了,React 的性能优化方向主要是两个:一个是减少重新 render 的次数(或者说减少不必要的渲染),另一个是减少计算的量。

      前面介绍的 React.memo 和 useCallback 都是为了减少重新 render 的次数。对于如何减少计算的量,就是 useMemo 来做的,接下来我们看例子。

      function App() {
        const [num, setNum] = useState(0);
      
        // 一个非常耗时的一个计算函数
        // result 最后返回的值是 49995000
        function expensiveFn() {
          let result = 0;
          
          for (let i = 0; i < 10000; i++) {
            result += i;
          }
          
          console.log(result) // 49995000
          return result;
        }
      
        const base = expensiveFn();
      
        return (
          <div className="App">
            <h1>count:{num}</h1>
            <button onClick={() => setNum(num + base)}>+1</button>
          </div>
        );
      }
      function App() {
        const [num, setNum] = useState(0);
      
        // 一个非常耗时的一个计算函数
        // result 最后返回的值是 49995000
        function expensiveFn() {
          let result = 0;
          
          for (let i = 0; i < 10000; i++) {
            result += i;
          }
          
          console.log(result) // 49995000
          return result;
        }
      
        const base = expensiveFn();
      
        return (
          <div className="App">
            <h1>count:{num}</h1>
            <button onClick={() => setNum(num + base)}>+1</button>
          </div>
        );
      }

      首次渲染的效果如下:

      这个例子功能很简单,就是点击 +1 按钮,然后会将现在的值(num) 与 计算函数 (expensiveFn) 调用后的值相加,然后将和设置给 num 并显示出来,在控制台会输出 49995000。

      可能产生性能问题

      就算是一个看起来很简单的组件,也有可能产生性能问题,通过这个最简单的例子来看看还有什么值得优化的地方。

      首先我们把 expensiveFn 函数当做一个计算量很大的函数(比如你可以把 i 换成 10000000),然后当我们每次点击 +1 按钮的时候,都会重新渲染组件,而且都会调用 expensiveFn 函数并输出 49995000。由于每次调用 expensiveFn 所返回的值都一样,所以我们可以想办法将计算出来的值缓存起来,每次调用函数直接返回缓存的值,这样就可以做一些性能优化。

      useMemo 做计算结果缓存

      针对上面产生的问题,就可以用 useMemo 来缓存 expensiveFn 函数执行后的值。

      首先介绍一下 useMemo 的基本的使用方法,详细的使用方法可见官网:

      function computeExpensiveValue() {
        // 计算量很大的代码
        return xxx
      }
      
      const memoizedValue = useMemo(computeExpensiveValue, [a, b]);
      function computeExpensiveValue() {
        // 计算量很大的代码
        return xxx
      }
      
      const memoizedValue = useMemo(computeExpensiveValue, [a, b]);

      useMemo 的第一个参数就是一个函数,这个函数返回的值会被缓存起来,同时这个值会作为 useMemo 的返回值,第二个参数是一个数组依赖,如果数组里面的值有变化,那么就会重新去执行第一个参数里面的函数,并将函数返回的值缓存起来并作为 useMemo 的返回值 。

      了解了 useMemo 的使用方法,然后就可以对上面的例子进行优化,优化代码如下:

      function App() {
        const [num, setNum] = useState(0);
      
        function expensiveFn() {
          let result = 0;
          for (let i = 0; i < 10000; i++) {
            result += i;
          }
          console.log(result)
          return result;
        }
      
        const base = useMemo(expensiveFn, []);
      
        return (
          <div className="App">
            <h1>count:{num}</h1>
            <button onClick={() => setNum(num + base)}>+1</button>
          </div>
        );
      }
      function App() {
        const [num, setNum] = useState(0);
      
        function expensiveFn() {
          let result = 0;
          for (let i = 0; i < 10000; i++) {
            result += i;
          }
          console.log(result)
          return result;
        }
      
        const base = useMemo(expensiveFn, []);
      
        return (
          <div className="App">
            <h1>count:{num}</h1>
            <button onClick={() => setNum(num + base)}>+1</button>
          </div>
        );
      }

      执行上面的代码,然后现在可以观察无论我们点击 +1多少次,只会输出一次 49995000,这就代表 expensiveFn 只执行了一次,达到了我们想要的效果。

      小结

      useMemo 的使用场景主要是用来缓存计算量比较大的函数结果,可以避免不必要的重复计算,有过 vue 的使用经历同学可能会觉得跟 Vue 里面的计算属性有异曲同工的作用。

      不过另外提醒两点

      一、如果没有提供依赖项数组,useMemo 在每次渲染时都会计算新的值;

      二、计算量如果很小的计算函数,也可以选择不使用 useMemo,因为这点优化并不会作为性能瓶颈的要点,反而可能使用错误还会引起一些性能问题。

      总结

      对于性能瓶颈可能对于小项目遇到的比较少,毕竟计算量小、业务逻辑也不复杂,但是对于大项目,很可能是会遇到性能瓶颈的,但是对于性能优化有很多方面:网络、关键路径渲染、打包、图片、缓存等等方面,具体应该去优化哪方面还得自己去排查,本文只介绍了性能优化中的冰山一角:运行过程中 React 的优化。

      1. React 的优化方向:减少 render 的次数;减少重复计算。
      2. 如何去找到 React 中导致性能问题的方法,见 useCallback 部分。
      3. 合理的拆分组件其实也是可以做性能优化的,你这么想,如果你整个页面只有一个大的组件,那么当 props 或者 state 变更之后,需要 reconction 的是整个组件,其实你只是变了一个文字,如果你进行了合理的组件拆分,你就可以控制更小粒度的更新。

      合理拆分组件还有很多其他好处,比如好维护,而且这是学习组件化思想的第一步,合理的拆分组件又是一门艺术了,如果拆分得不合理,就有可能导致状态混乱,多敲代码多思考。

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

      上一篇:Layout_marginTop与Layout_marginBottom详解

      下一篇:Linux 挂载磁盘详解及实操步骤

      相关文章

      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-16 09:15:24

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

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

      2025-05-16 09:15:24
      函数 , 数字 , 数组
      2025-05-14 10:33:31

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

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

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

      计算机小白的成长历程——习题演练(函数篇)

      计算机小白的成长历程——习题演练(函数篇)

      2025-05-14 10:33:31
      函数 , 字符串 , 数组 , 知识点 , 编写 , 迭代 , 递归
      2025-05-14 10:33:25

      30天拿下Rust之高级类型

      Rust作为一门系统编程语言,以其独特的内存管理方式和强大的类型系统著称。其中,高级类型的应用,为Rust的开发者提供了丰富的编程工具和手段,使得开发者可以更加灵活和高效地进行编程。

      2025-05-14 10:33:25
      Rust , type , 代码 , 函数 , 类型 , 返回
      2025-05-14 10:33:16

      30天拿下Python之文件操作

      Python是一种高级编程语言,它提供了许多内置函数和模块来处理文件操作,主要包括:打开文件、读取文件、写入文件、关闭文件、获取目录列表等。

      2025-05-14 10:33:16
      Python , 使用 , 函数 , 文件 , 权限 , 目录
      2025-05-14 10:33:16

      C++ 11新特性之tuple

      在C++编程语言的发展历程中,C++ 11标准引入了许多开创性的新特性,极大地提升了开发效率与代码质量。其中,tuple(元组)作为一种强大的容器类型,为处理多个不同类型的值提供了便捷的手段。

      2025-05-14 10:33:16
      std , 元素 , 函数 , 初始化 , 模板 , 类型
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5239704

      查看更多

      最新文章

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

      2025-05-19 09:04:44

      30天拿下Rust之函数详解

      2025-05-14 10:02:58

      Element学习(布局组件、案例操作)(4)

      2025-05-09 08:50:35

      STL:模版进阶 | Priority_queue的模拟实现

      2025-05-09 08:20:32

      剑指 Offer 30. 包含min函数的栈

      2025-05-08 09:03:47

      Qt中音频的使用

      2025-05-07 09:08:23

      查看更多

      热门文章

      Neon Intrinsics各函数介绍

      2023-04-10 08:53:07

      python学习——函数的参数

      2023-04-04 08:09:07

      自定义函数基础(内有实操)

      2023-03-15 09:28:04

      【DockerImage】修复Docker镜像的组件安全漏洞(原创)

      2024-07-01 01:32:37

      React工作17:ant design form格式化日期

      2023-05-12 06:47:28

      React-Redux-实现原理

      2023-04-23 09:44:14

      查看更多

      热门标签

      linux java python javascript 数组 前端 docker Linux vue 函数 shell git 节点 容器 示例
      查看更多

      相关产品

      弹性云主机

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

      天翼云电脑(公众版)

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

      对象存储

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

      云硬盘

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

      查看更多

      随机文章

      Android Service

      根据函数名称动态调用

      vue组件通信

      React工作41:react中的jsx简介

      标准I/O操作函数

      因子和与因子个数 (乘性函数)求n!中含有某个因子个数的方法

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