原生求生记:揭秘UniApp的原生能力限制

news/2024/4/29 0:19:45/文章来源:https://blog.csdn.net/weixin_42554191/article/details/131995616

在这里插入图片描述

文章目录

    • 1. 样式适配问题
    • 2. 性能问题
    • 3. 原生能力限制
    • 4. 插件兼容性问题
    • 5. 第三方组件库兼容性问题
    • 6. 全局变量污染
    • 7. 调试和定位问题
    • 8. 版本兼容性问题
    • 9. 前端生态限制
    • 10. 文档和支持
    • 附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

📈「作者简介」:前端开发工程师 | 蓝桥云课签约作者 | 技术日更博主 | 已过四六级
📚「个人主页」:阿珊和她的猫
🕐「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

  • Vue.js 和 Egg.js 开发企业级健康管理项目
  • 带你从入门到实战全面掌握 uni-app

使用 UniApp 进行跨平台应用开发时,以下是一些常见的坑点:

1. 样式适配问题

不同平台对样式的支持和渲染有所差异,需要针对每个平台进行适配,保证在各个平台上的显示效果一致。
当涉及到在不同平台上适配样式时,以下是一个常见的代码示例,展示如何使用条件类来应用特定平台的样式:

<template><div class="container"><div :class="['box', {'ios-style': isIOS, 'android-style': isAndroid}]"></div></div>
</template><style>
.container {width: 100%;height: 100%;display: flex;justify-content: center;align-items: center;
}.box {width: 200px;height: 200px;background-color: gray;
}.ios-style {background-color: lightblue;
}.android-style {background-color: lightgreen;
}
</style><script>
export default {data() {return {isIOS: false,isAndroid: false};},mounted() {this.checkPlatform();},methods: {checkPlatform() {// 检测当前运行平台this.isIOS = uni.getSystemInfoSync().platform === 'ios';this.isAndroid = uni.getSystemInfoSync().platform === 'android';}}
};
</script>

在上述示例中,通过在模板中使用动态的 class 绑定,根据当前平台设置不同的类来应用特定样式。在样式部分,可以编写针对 iOS 和 Android 的各自样式。在 mounted 钩子中,通过 uni.getSystemInfoSync() 获取运行平台的信息,并根据平台设置对应的数据属性。然后,在模板的 class 绑定中使用这些数据属性来动态添加样式类,从而实现在不同平台上的样式适配。

通过这种方式,你可以根据需要对不同平台上的样式进行适配,并根据特定的样式需求为每个平台提供特定的视觉效果。请注意,这只是一个简单的示例,你可以根据项目的实际需求进行更复杂的样式适配。

2. 性能问题

在处理大量数据和复杂的动画效果时,UniApp 可能面临性能瓶颈。需要注意优化渲染性能,如合理使用虚拟滚动、避免频繁操作 DOM 等。

对于处理性能问题,以下是一个代码示例,展示如何使用虚拟滚动来优化大数据列表的渲染:

<template><div class="container" ref="container"><div class="list-wrapper" :style="{height: listHeight + 'px'}"><div class="list-item" v-for="item in virtualList" :key="item.id">{{ item.name }}</div></div></div>
</template><style>
.container {width: 100%;height: 100%;overflow: auto;
}.list-wrapper {position: relative;border: 1px solid #ccc;overflow: hidden;
}.list-item {height: 50px;line-height: 50px;padding: 0 10px;
}
</style><script>
export default {data() {return {list: [], // 传入的原始数据列表virtualList: [], // 用于展示的虚拟列表listHeight: 0, // 列表的高度visibleCount: 10, // 可见的列表项数量itemHeight: 50, // 单个列表项的高度scrollTop: 0 // 滚动的距离};},mounted() {this.getListData(); // 获取数据,可从服务器或本地获取this.setListHeight(); // 设置列表高度this.setVirtualList(); // 设置虚拟列表展示的数据this.addScrollEvent(); // 监听滚动事件},methods: {getListData() {// 从服务器或本地获取数据列表// 示例:this.list = axios.get('api/list');this.list = [{ id: 1, name: 'Item 1' },{ id: 2, name: 'Item 2' },// ...{ id: 1000, name: 'Item 1000' }];},setListHeight() {// 计算列表的高度this.listHeight = this.list.length * this.itemHeight;},setVirtualList() {// 根据滚动位置和可见数量设置虚拟列表展示的数据const start = Math.floor(this.scrollTop / this.itemHeight);const end = start + this.visibleCount;this.virtualList = this.list.slice(start, end);},addScrollEvent() {// 监听滚动事件,实时更新虚拟列表展示的数据this.$refs.container.addEventListener('scroll', () => {this.scrollTop = this.$refs.container.scrollTop;this.setVirtualList();});}}
};
</script>

在上述示例中,我们使用虚拟滚动的方式来优化大数据列表的渲染。通过计算列表的高度和滚动位置,我们只渲染可见范围内的列表项,而不是直接渲染全部列表项。这种方式可以减少 DOM 元素的数量,提高渲染性能。

mounted 钩子中,我们获取数据列表,并根据数据的数量计算列表的高度。然后,我们设置一个虚拟列表,根据滚动位置和可见数量来切片展示需要渲染的列表项。通过监听滚动事件,我们实时更新滚动位置并重新计算并展示虚拟的列表项。

需要注意的是,虚拟滚动适用于大数据列表,但对于小型数据列表可能会带来额外的复杂性。因此,在实际应用中需要根据具体情况进行评估和选择是否使用虚拟滚动来优化性能。

3. 原生能力限制

UniApp 封装了一套跨平台的 API,但某些特定的原生功能可能无法在所有平台上完全支持。需要了解每个平台的能力差异,并适配业务需求。

在某些情况下,UniApp的跨平台能力可能会受到原生能力的限制。以下是一个代码示例,演示如何使用条件编译来处理不同平台的原生能力限制:

export default {methods: {// 调用原生分享功能share() {#ifdef APP-PLUS// 在APP-PLUS环境下,调用原生分享功能plus.share.sendWithSystem({ content: 'Hello, World!' });#endif#ifdef H5// 在H5环境下,提示用户无法使用原生分享功能alert('抱歉,当前环境不支持原生分享功能!');#endif}}
};

在上述示例中,我们使用了条件编译指令来根据不同平台处理原生能力的限制。在 share 方法中,我们根据当前平台的不同来执行不同的代码逻辑。

APP-PLUS 环境下,我们调用了 plus.share.sendWithSystem 方法,该方法是原生平台提供的分享功能。而在 H5 环境下,我们通过 alert 弹窗来提示用户当前环境不支持原生分享功能。

通过使用条件编译,可以在不同平台下针对原生能力的限制执行特定的代码逻辑。在实际应用中,你可以根据需求和特定平台的限制,为不同平台提供定制化的处理方式,以保证应用的兼容性和性能。

4. 插件兼容性问题

UniApp 支持使用插件扩展功能,但并非所有原生插件都能完全支持跨平台。需要谨慎选择插件,并测试其在不同平台上的兼容性。

在UniApp中,插件兼容性可能是一个常见的问题。以下是一个代码示例,演示如何使用条件编译来处理不同平台下的插件兼容性问题:

<template><div><div v-if="isPluginSupported"><!-- 在支持插件的平台下渲染插件内容 --><plugin-component /></div><div v-else><!-- 在不支持插件的平台下提供替代方案 --><p>当前环境不支持该插件,请使用其他功能替代。</p></div></div>
</template><script>
export default {computed: {isPluginSupported() {#ifdef APP-PLUS// 在APP-PLUS环境下,检查插件是否可用return typeof uni.requireNativePlugin !== 'undefined';#endif#ifdef H5// 在H5环境下,检查插件是否可用return typeof window.PluginComponent !== 'undefined';#endif// 其他平台默认支持插件return true;}}
};
</script>

在上述示例中,我们使用了条件编译指令来处理不同平台下的插件兼容性问题。在模板部分,我们根据不同平台的插件支持情况渲染不同的内容。

isPluginSupported 计算属性中,我们使用条件编译指令来检查当前平台下插件的可用性。在 APP-PLUS 环境下,我们通过检查 uni.requireNativePlugin 方法是否定义来判断插件的可用性。在 H5 环境下,我们通过检查 window.PluginComponent 对象是否定义来判断插件的可用性。其他平台默认认为支持插件。

根据插件的支持情况,我们在模板中渲染不同的内容。在支持插件的平台下,我们渲染插件组件的内容。而在不支持插件的平台下,我们通过提供替代方案来告知用户当前环境不支持该插件,并建议使用其他功能替代。

通过使用条件编译,我们可以根据不同平台提供定制化的插件兼容处理方式,以保证应用在不同环境下的正常运行。请根据具体插件的兼容性问题和需求进行相应的处理。

5. 第三方组件库兼容性问题

使用第三方组件库时,需注意其在 UniApp 中的兼容性。某些常用组件可能无法在 UniApp 中完全支持。

在UniApp中使用第三方组件库时,兼容性问题是一项重要的考虑因素。以下是一个代码示例,展示如何利用条件编译来处理不同平台下的第三方组件库兼容性问题:

<template><div><div v-if="isComponentSupported"><!-- 在支持组件库的平台下渲染组件 --><third-party-component /></div><div v-else><!-- 在不支持组件库的平台下提供替代方案 --><p>当前环境不支持该组件库,请使用其他方式实现相同的功能。</p></div></div>
</template><script>
export default {computed: {isComponentSupported() {#ifdef APP-PLUS// 在APP-PLUS环境下,检查第三方组件库是否可用return typeof uni.component.isDefined !== 'undefined' && uni.component.isDefined('third-party-component');#endif#ifdef H5// 在H5环境下,检查第三方组件库是否可用return typeof window.ThirdPartyComponent !== 'undefined';#endif// 其他平台默认支持第三方组件库return true;}}
};
</script>

在上述示例中,我们使用条件编译指令来处理不同平台下的第三方组件库兼容性问题。在模板部分,根据不同平台的兼容性情况渲染不同的内容。

isComponentSupported 计算属性中,我们利用条件编译指令来检查第三方组件库在当前平台下的可用性。在 APP-PLUS 环境下,我们检查 uni.component.isDefined 方法是否定义,并使用 uni.component.isDefined('third-party-component') 方法来判断组件库的可用性。在 H5 环境下,我们通过检查 window.ThirdPartyComponent 对象是否定义来判断组件库的可用性。其他平台默认认为支持第三方组件库。

根据组件库的支持情况,我们在模板中渲染不同的内容。在支持组件库的平台下,我们渲染第三方组件的内容。而在不支持组件库的平台下,我们通过提供替代方案来告知用户当前环境不支持该组件库,并建议使用其他方式实现相同的功能。

通过使用条件编译,我们可以根据不同平台提供定制化的第三方组件库兼容处理方式,以确保应用在不同环境下的兼容性。需要根据具体的第三方组件库的兼容性问题和需求进行相应的处理。

6. 全局变量污染

在多页面应用中,全局变量容易造成冲突和污染。需要合理使用全局变量,并考虑模块化开发和命名空间的使用。

全局变量污染是一个常见的问题,特别是在多人协作开发或使用第三方库时。以下是一个简单的代码示例,展示如何避免全局变量污染问题:

// 使用IIFE(Immediately Invoked Function Expression)在函数作用域中定义变量,避免全局变量污染
(function() {// 在函数作用域内定义变量var localVariable = '局部变量';// 将需要暴露给外部的变量或方法赋值给全局对象window.myObject = {globalVariable: '全局变量',getLocalVariable: function() {return localVariable;},// ...其他方法和属性};
})();

在上述示例中,我们使用了立即执行函数表达式(IIFE)将变量封装在函数作用域内,避免了对全局命名空间的直接污染。

在 IIFE 中,我们在函数作用域内定义了一个局部变量 localVariable。然后,我们将需要暴露给外部的变量或方法赋值给全局对象(在这里我们使用 window)。在示例中,我们将 globalVariablegetLocalVariable 方法暴露给全局对象 myObject,其他方法和属性也可以按需添加。

这样做的好处是,通过将变量封装在函数作用域内,可以避免变量在全局范围内被访问和修改,从而避免全局变量之间的命名冲突和污染问题。

你可以根据实际需求将代码封装在模块中,或使用模块化的解决方案(如ES Modules、CommonJS、AMD等)来避免全局变量污染问题,并更好地组织和管理代码。

7. 调试和定位问题

UniApp 提供了调试工具和相关 API,但某些情况下可能仍然难以准确定位问题。需依赖调试工具和技术手段,如使用调试器、打印日志等。

8. 版本兼容性问题

UniApp 的版本更新可能会引入新的功能或修复旧版问题,但也可能导致兼容性问题。在升级 UniApp 版本时需要进行测试和验证,确保应用的稳定性和正常运行。

在开发 UniApp 应用时,确保应用在不同版本的 UniApp 上具有兼容性是很重要的。以下是一些常见的 UniApp 版本兼容性问题和相应的处理方法:

  1. 语法兼容性问题:在不同版本的 UniApp 中,可能会存在语法差异和更新的 API。为了解决这个问题,可以使用条件编译来根据不同版本执行不同的代码。例如:

    #ifdef H5
    // H5环境特定代码
    #endif#ifdef APP-PLUS
    // APP-PLUS环境特定代码
    #endif// 其他平台默认代码
    

    根据目标平台使用特定代码块,以确保在不同版本的 UniApp 上正常运行。

  2. 组件和 API 兼容性问题:在开发过程中,确保使用的组件和 API 在目标版本上可用。可以通过检查组件的文档或 API 文档来确认其兼容性,并在使用时进行相应的条件判断和兼容处理。

  3. 样式兼容性问题:不同平台的 CSS 呈现可能存在差异,因此在编写样式时应谨慎处理。可以利用 @media 查询和条件编译来为不同平台设置特定样式。例如:

    /* H5平台特定样式 */
    @media (min-height: 500px) {/* H5平台下的样式处理 */
    }/* APP-PLUS平台特定样式 */
    #ifdef APP-PLUS
    /* APP-PLUS平台下的样式处理 */
    #endif/* 其他平台默认样式 */
    

    通过使用媒体查询和条件编译,可以根据不同平台应用特定的样式,以保证在各个平台上呈现一致的效果。

  4. 插件和扩展的兼容性问题:在使用第三方插件和扩展时,确保它们与目标版本的 UniApp 兼容。应仔细阅读插件和扩展的文档,了解其支持的 UniApp 版本,以避免兼容性问题。

总之,在开发 UniApp 应用时,需要关注不同版本之间的兼容性问题。可以利用条件编译、条件判断和查询文档等方式来进行版本兼容处理,以确保应用在各个版本的 UniApp 上都可以正常运行。

9. 前端生态限制

UniApp 使用的是 Vue.js 的前端框架,但与原生的 Vue.js 有一些差异和限制。需要了解并适应 UniApp 的前端生态特点。

UniApp是一个跨平台的前端框架,封装了许多特性和API,但也存在一些前端生态的限制。以下是一些常见的UniApp前端生态限制:

  1. 平台差异限制:虽然UniApp提供了一套统一的开发框架,但不同平台仍然存在一些差异。这导致某些功能在某些平台上可能不完全支持或表现不一致。开发者需要在编写代码时认识到这些差异,并根据实际情况进行兼容处理。

  2. 第三方插件限制:UniApp允许使用一些第三方插件来增强应用功能,但并非所有的第三方插件都能完美地在UniApp中使用。开发者需要在选择插件时仔细查看插件文档和兼容性,确保插件与UniApp的版本和目标平台兼容。

  3. 性能限制:由于UniApp是一个跨平台框架,它会在不同的平台上运行应用。这可能会导致一些性能上的限制,例如某些复杂的动画或渲染操作在某些平台上的性能表现可能不理想。开发者需要在编写代码时注意性能问题,并进行相应的优化。

  4. 社区生态系统限制:相比于其他主流的前端框架,UniApp的社区生态系统可能相对较小。这意味着可能存在较少的开源组件、工具和解决方案可供选择。开发者可能需要自行解决某些问题,或者依赖少量的可用资源来满足需求。

  5. 更新频率限制:UniApp的更新频率相对较慢,新功能和修复bug的周期可能会较长。这可能会限制开发者在应用中使用最新的前端技术和功能。开发者需要根据具体需求权衡使用UniApp的稳定性和前沿特性。

总结来说,UniApp作为一个跨平台的前端框架,在带来跨平台开发便利性的同时,也存在一些生态限制。开发者需要在使用UniApp时考虑这些限制,并根据实际情况做出相应的权衡和兼容处理。

10. 文档和支持

由于 UniApp 是相对较新的技术,相关问题的解答和支持资源相对有限。在开发过程中可能需要自行查找资料和尝试解决问题。

了解和熟悉这些坑点,合理规划项目开发,加强测试和调试环节,可以提高使用 UniApp 进行跨平台应用开发的效率和质量。

附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

Vue.js 和 Egg.js 开发企业级健康管理项目
带你从入门到实战全面掌握 uni-app

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_337179.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用小波包对一维信号进行降噪或压缩(MATLAB)

function [ output_args ] example4_12( input_args ) %EXAMPLE4_12 Summary of this function goes here % Detailed explanation goes here clc; clear; % 设置信噪比和随机数的初始值 snr 3; init 2055615866; % 生成一个原始信号xref和含高斯白噪声的信号x [xref,x] …

网络安全/信息安全(黑客技术)自学笔记

一、网络安全基础知识 1.计算机基础知识 了解了计算机的硬件、软件、操作系统和网络结构等基础知识&#xff0c;可以帮助您更好地理解网络安全的概念和技术。 2.网络基础知识 了解了网络的结构、协议、服务和安全问题&#xff0c;可以帮助您更好地解决网络安全的原理和技术…

2023年的深度学习入门指南(22) - 百川大模型13B的运行及量化

2023年的深度学习入门指南(22) - 百川大模型13B的运行及量化 不知道上一讲的大段代码大家看晕了没有。但是如果你仔细看了会发现&#xff0c;其实代码还是不全的。比如分词器我们就没讲。 另外&#xff0c;13B比7B的改进点也没有讲。 再有&#xff0c;对于13B需要多少显存我们…

记录每日LeetCode 141.环形链表 Java实现

题目描述&#xff1a; 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连接到链…

【RTT驱动框架分析00】-应用层函数调用流程-串口为例

应用层函数调用流程分析以-串口为例 1. rt_device_find调用流程 RTT内部有一个全局变量数组rt_object_container数组的数量就是 rt_object_info_type 内核对象的种类&#xff0c;其中包含一个RT_USING_DEVICE (设备的数据类型)&#xff0c;数组内部的每一个变量包含一个链表&…

基于扩展(EKF)和无迹卡尔曼滤波(UKF)的电力系统动态状态估计(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

C\C++内存管理

目录 1.C/C内存分布2.C语言中动态内存管理方式3.C中动态内存管理3.1new/delete内置类型3.2new和delete操作自定义类型 4.operator new与operator delete函数4.2重载operator new与operator delete&#xff08;了解&#xff09; 5.new和delete的实现原理5.1内置类型5.2 自定义类…

【动态规划part12】| 309.买卖股票的最佳时机含冷冻期、714.买卖股票的最佳时机含手续费

目录 &#x1f388;LeetCode309.最佳买卖股票时机含冷冻期 &#x1f388;LeetCode714.买卖股票的最佳时机含手续费 &#x1f388;LeetCode309.最佳买卖股票时机含冷冻期 给定一个整数数组prices&#xff0c;其中第 prices[i] 表示第 i 天的股票价格 。​ 设计一个算法计…

【计算机视觉中的 GAN 】如何稳定GAN训练(3)

一、说明 在上一篇文章中&#xff0c;我们达到了理解未配对图像到图像翻译的地步。尽管如此&#xff0c;在实现自己的超酷深度GAN模型之前&#xff0c;您必须了解一些非常重要的概念。如本文所提的GAN模型新成员的引入&#xff1a;Wasserstein distance&#xff0c;boundary eq…

element时间选择器的默认值

概览&#xff1a;vue使用element组件&#xff0c;需要给时间选择器设置默认值&#xff0c;场景一&#xff1a;默认时间选择器&#xff0c;场景二&#xff1a;时间范围选择器&#xff0c;开始时间和结束时间。 一、默认时间选择器 实现思路&#xff1a; element组件的v-model绑…

DevOps-Jenkins

Jenkins Jenkins是一个可扩展的持续集成引擎&#xff0c;是一个开源软件项目&#xff0c;旨在提供一个开放易用的软件平台&#xff0c;使软件的持续集成变成可能。 官网 应用场景 场景一 研发人员上传开发好的代码到github代码仓库需要将代码下载nginx服务器部署手动下载再…

数值线性代数:奇异值分解SVD

本文记录计算矩阵奇异值分解SVD的原理与流程。 注1&#xff1a;限于研究水平&#xff0c;分析难免不当&#xff0c;欢迎批评指正。 零、预修 0.1 矩阵的奇异值 设列满秩矩阵&#xff0c;若的特征值为&#xff0c;则称为矩阵的奇异值。 0.2 SVD(分解)定理 设&#xff0c;则…

Open3D-ML自动驾驶点云目标检测与分割入门

当开始新的研究时&#xff0c;我的方法通常是测试不同的相关事物&#xff0c;直到有足够的经验让我开始将这些点联系起来。 在开始构建用于 3D 对象检测的自定义模型之前&#xff0c;我购买了一台 LiDAR 并处理了一些数据。 下一个明显的步骤是在我为自己的数据贴标签之前找出研…

SpringCloudAlibaba之Ribbon

Ribbon是nacos自带的负载均衡器&#xff0c;属于客户端的负载均衡 但是在Spring高级版本中让LoadBalancer替代了 本人用的是2.1.0的nacos&#xff0c;ribbon还没有被替换。 使用&#xff1a; 在配置类中&#xff1a;LoadBalanced BeanLoadBalancedpublic RestTemplate restT…

ChatGPT长文本对话输入方法

ChatGPT PROMPTs Splitter 是一个开源工具&#xff0c;旨在帮助你将大量上下文数据分成更小的块发送到 ChatGPT 的提示&#xff0c;并根据如何处理所有块接收到 ChatGPT&#xff08;或其他具有字符限制的语言模型&#xff09;的方法。 推荐&#xff1a;用 NSDT设计器 快速搭建可…

【FPGA IP系列】FIFO的通俗理解

FPGA厂商提供了丰富的IP核&#xff0c;基础性IP核都是可以直接免费调用的&#xff0c;比如FIFO、RAM等等。 本文主要介绍FIFO的一些基础知识&#xff0c;帮助大家能够理解FIFO的基础概念。 一、FIFO介绍 FIFO全称是First In First Out&#xff0c;即先进先出。 FIFO是一个数…

怎么选择合适的微信管理系统?

稳定好用的网页版微信CRM系统&#xff0c;随时随地可以登录&#xff0c;不用安排插件软件&#xff0c;不限制手机和电脑使用&#xff0c;电脑手机关机消息都是实时同步的 还有很多功能&#xff1a; 1、聚合聊天&#xff1a;支持多个微信号登录到系统上&#xff0c;一个页面就可…

WIZnet W51000S-EVB-PICO 入门教程(一)

概述 W5100S-EVB-Pico是基于树莓派RP2040和全硬件TCP/IP协议栈控制器W5100S的微控制器开发板-基本上与树莓派Pico板相同&#xff0c;但通过W5100S芯片增加了以太网功能。 W5100S-EVB-Pico特点 RP2040规格参数 双核Arm Cortex-M0 133MHz264KB 高速SRAM和2MB板载内存通过…

【计算机视觉中的 GAN 】 - 生成学习简介(1)

一、说明 在阅读本文之前&#xff0c;强烈建议先阅读预备知识&#xff0c;否则缺乏必要的推理基础。本文是相同理论GAN原理的具体化范例&#xff0c;阅读后有两个好处&#xff1a;1 巩固了已经建立的GAN基本概念 2 对具体应用的过程和套路进行常识学习&#xff0c;这种练习题一…

RocketMQ概论

目录 前言&#xff1a; 1.概述 2.下载安装、集群搭建 3.消息模型 4.如何保证吞吐量 4.1.消息存储 4.1.1顺序读写 4.1.2.异步刷盘 4.1.3.零拷贝 4.2.网络传输 前言&#xff1a; RocketMQ的代码示例在安装目录下有全套详细demo&#xff0c;所以本文不侧重于讲API这种死…