为什么有点旗有用吗?

为什么有点旗有用吗?
精明的读者会注意到,上述myflags例子其实并不保存任何记忆。8布尔型通常需要8个字节。但上面的例子使用了9个字节(8个字节来定义的选项,和1个字节的位标志)!那么,为什么你要使用位标志?
在2种情况下,通常使用位标志:
1)当你有多台相同的bitflags。
而不是一个单一的myflags变量,考虑下你有两myflags变量的情况:myflags1和myflags2,每一个都可以存储8个选项。如果你定义了这些作为布尔值两套分开,你需要16个布尔值,因此16字节。然而,使用标志位、存储成本仅10(8字节定义的选项,并为每个myflags可变字节1)。100 myflag变量,你的内存成本将是108字节而不是800。你需要的更为相同的变量,你的记忆更大。
让我们来看一个更具体的例子。想象一下你正在创造一个游戏,玩家可以在游戏中战斗。当怪物被创造出来时,它可以抵抗某些类型的攻击(随机选择)。在游戏中的不同类型的攻击是:毒药,闪电,火,冷,盗窃,酸,麻痹,失明。
为了追踪怪物的攻击类型,我们可以使用一个布尔值(每个怪物)。这8个布尔值每怪物。

用100个怪物,那就需要800个布尔变量,用800个字节的内存。

1
2
3
4
5
6
7
8
const unsigned char resistsPoison    = 0x01;
const unsigned char resistsLightning = 0x02;
const unsigned char resistsFire      = 0x04;
const unsigned char resistsCold      = 0x08;
const unsigned char resistsTheft     = 0x10;
const unsigned char resistsAcid      = 0x20;
const unsigned char resistsParalysis = 0x40;
const unsigned char resistsBlindness = 0x80;
使用位标志,我们只需要一个字节存储的电阻为一个单一的怪物,再加上一次性设置费用为8字节的选项。
与100个怪物,这将占用108个字节,或约8倍的内存。
对于大多数程序,使用位标志保存的内存量是不值得的增加的复杂性。但是在有成千上万甚至数百万的类似对象的程序中,使用位标志可以大大减少内存的使用。这是一个有用的优化,在您的工具箱,如果您需要它。
2)想象你有一个可以采取32种不同的选择组合的功能。编写该函数的一个方法是使用32个单独的布尔参数:

void someFunction(bool option1, bool option2, bool option3, bool option4, bool option5, bool option6, bool option7, bool option8, bool option9, bool option10, bool option11, bool option12, bool option13, bool option14, bool option15, bool option16, bool option17, bool option18, bool option19, bool option20, bool option21, bool option22, bool option23, bool option24, bool option25, bool option26, bool option27, bool option28, bool option29, bool option30, bool option31, bool option32);



资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在本文中,我们将探讨如何通过 Vue.js 实现一个带有动画效果的“回到顶部”功能。Vue.js 是一款用于构建用户界面的流行 JavaScript 框架,其组件化和响应式设计让实现这种交互功能变得十分便捷。 首先,我们来分析 HTML 代码。在这个示例中,存在一个 ID 为 back-to-top 的 div 元素,其中包含两个 span 标签,分别显示“回到”和“顶部”文字。该 div 元素绑定了 Vue.js 的 @click 事件处理器 backToTop,用于处理点击事件,同时还绑定了 v-show 指令来控制按钮的显示与隐藏。v-cloak 指令的作用是在 Vue 实例渲染完成之前隐藏该元素,避免出现闪烁现象。 CSS 部分(backTop.css)主要负责样式设计。它首先清除了一些默认的边距和填充,对 html 和 body 进行了全屏布局,并设置了相对定位。.back-to-top 类则定义了“回到顶部”按钮的样式,包括其位置、圆角、阴影、填充以及悬停时背景颜色的变化。此外,与 v-cloak 相关的 CSS 确保在 Vue 实例加载过程中隐藏该元素。每个 .page 类代表一个页面,每个页面的高度设置为 400px,用于模拟多页面的滚动效果。 接下来是 JavaScript 部分(backTop.js)。在这里,我们创建了一个 Vue 实例。实例的 el 属性指定 Vue 将挂载到的 DOM 元素(#back-to-top)。data 对象中包含三个属性:backTopShow 用于控制按钮的显示状态;backTopAllow 用于防止用户快速连续点击;backSeconds 定义了回到顶部所需的时间;showPx 则规定了滚动多少像素后显示“回到顶部”按钮。 在 V
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值