位数组

假设须要处理非常多位,就能够使用BitArray类和BitVector32.BitArray位于命名空间System.Collections中.

BitVector32位于命名空间System.Collections.Speciallized.

BitArray类

类BitArray是一个引用引用类型,包括一个int数组,没32位使用一个新整数.和bool类型的数组bool[]几乎相同

案例:

using System;

using System.Collections;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

namespace 可观察的集合

{

class Program

{

static void Main(string[] args)

{

Stack st = new Stack();

st.Push('A');

st.Push('B');

st.Push('C');

BitArray bits1 = new BitArray(8);//一个有8位的数组

Console.WriteLine("显示数组中全部位的默认值:");

Display(bits1);

Console.WriteLine();

bits1.SetAll(true);//SetAll()方法将全部的位都置为1

bits1.Set(1, false);

bits1[5] = false;

bits1[7] = false;

Console.WriteLine("显示数组中全部位的值: ");

Display(bits1);

Console.WriteLine();

Console.WriteLine("倒转数组中全部位的值: ");

bits1.Not();//Not()方法的结果是所有的位所有翻转过来.假设某位是true,运行Not()方法的结果就是False

Display(bits1);

Console.ReadKey();

}

public static void Display(BitArray bits)

{

foreach (bool item in bits)

{

Console.WriteLine(item ?1 :0);

}

}

}

}

BitArray的其它方法:And(),Or().Xor(),Get()演示:

//BitArray的其它方法演示

Console.WriteLine();

BitArray bits2 = new BitArray(bits1);

bits2.Set(0, true);

bits2[1] = false;//效果同Set()方法

bits2[4] = false;

Console.WriteLine("bits2数组中全部位的值: ");

Display(bits2);

Console.WriteLine();

Console.WriteLine("bits1和bits2数组Or的值: ");

bits1.Or(bits2);

/*

* 使用And(),Or()和Xor()方法,能够合并两个BitArray对象

* And()方法运行二元AND,仅仅用两个输入数组的位都设置为1,结果位才是1

* Or()方法运行二元OR,仅仅要有一个输入数组的位设置为1,结果位就是1.

* Xor()方法是异或操作,仅仅有一个输入数组的位设置为1,结果位才是1

*/

Display(bits1);

Console.WriteLine();

Console.WriteLine("bits1数组Get数字2的值");

Console.WriteLine(bits1.Get(2));

Console.ReadKey();

BitVector32结构

相比与BitArray,它的有点事速度快,占用空间小,并能够存储小数字.它内部用一个32位的整数来存储数据,因此仅仅能存储32位的比特数据.

先来看一下简单的未操作,常见的位操作无非就是AND,OR,NOT.

案例:比方一个8位的数据:0000 1111

我们想把第二个0设置为1,那么把它和0100 0000进行或操作,就得到结果:0100 1111

还是上面的那个数:0000 1111,我们想把 最后一个1设置为0,那么把它和1111 1110这个数进行与操作,疾苦得到了结果:0000 1110

总结:想要操作一个位,我们把其它位都设置成0,把这个位设置成1,这个数就是所谓的位掩码(也成位屏蔽,MSDN里用的是为屏蔽)

那么假设想要打开一个位(就是把这个位设置成1):

源数据=源数据OR位掩码

想要关掉一个位:

源数据=源数据AND位掩码取反

解释:位掩码取反就是非(NOT)操作:0变1,1变0

BitVector32的位操作

了解了主要的位操作BitVector32的理解就会简单多了.

首先BitVector32本质上用一个32位的数来表示数据,那么初始化BitVector32结构时必须指定一个最初指.用户能够传入一个int或者还有一个已经存在的BitVector32来构造一个新的BitVector32.

BitVector32的Data属性返回一个int用来表示内部数据,假设用来显示BitVEctor32的内容,这个Data是没有意义的,由于它是十进制化的结果,这时候用BitVector32的ToString()方就能够返回实用的文字说明,案例:

//初始化BitVector32,设置低4位为1 0x 00 00 00 00 00 00 00 0F

BitVector32 bits = new BitVector32(0xF);

//(十六进制)0xF等于(二进制)1111等于(十进制)15

Console.WriteLine(bits.Data);

Console.WriteLine(bits.ToString());

接下来就是最重要的位操作了.

BitVector32结构体提供索引器(Indexer)能够直接通过bool对象操作BitVector32结构,索引器參数是int,这个int可不睡第几位的意思(BitArray中的索引器是第几位的意思),而是须要一个位掩码(位屏蔽),BitVector32通过这个位掩码来操作内部比特位.

所以,用BitVector32索引器操作事实上就是定义好位掩码,接着取回信息或者赋值就能够了.

案例:

static void Main(string[] args)

{

int mask1 = 1;

//掩码代表最后一位,二进制表示:0...0001

int mask2 = 4;

//掩码代表倒数第三位,二进制表示

C#高级编程五十七天----位数组的更多相关文章

  1. C#编程(五十七)----------位数组

    位数组 如果需要处理很多位,就可以使用BitArray类和BitVector32.BitArray位于命名空间System.Collections中. BitVector32位于命名空间System. ...

  2. C++面向对象高级编程(五)类与类之间的关系

    技术在于交流.沟通,转载请注明出处并保持作品的完整性. 本节主要介绍一下类与类之间的关系,也就是面向对象编程先介绍两个术语 Object Oriented Programming   OOP面向对象编 ...

  3. C#高级编程五十四天----Lookup类和有序字典

    Lookup类 Dictionary<Tkey,TValue>仅仅为每一个键支持一个值.新类Lookup<Tkey,TValue>是.NET3.5中新增的,它类似与Dictio ...

  4. 重学《C#高级编程》(泛型与数组)

    前段时间工作比较忙,就没有写随笔了,现在继续. 前两天重新看了泛型和数组两章,简单说下我自己的收获吧 泛型 我们知道数组是一种批量的数据格式,而泛型其实就是一种自定义的批量数据格式,当数组和C#现有的 ...

  5. Unix环境高级编程(五)进程环境

    本章主要介绍了Unix进程环境,包含main函数是如何被调用的,命令行参数如何传递,存储方式布局,分配存储空间,环境变量,进程终止方法,全局跳转longjmp和setjmp函数及进程的资源限制. ma ...

  6. C#高级编程五十八天----并行集合

    并行集合 对于并行任务,与其相关紧密的就是对一些共享资源,数据结构的并行訪问.常常要做的就是对一些队列进行加锁-解锁,然后运行类似插入,删除等等相互排斥操作. .NET4提供了一些封装好的支持并行操作 ...

  7. C#高级编程五十二天----有序列表

    有序列表 假设须要基于对全部集合排序,就能够使用SortedList<TKey,TValue>类.这个类依照键给元素排序.这个集合中的值和键都能够使用随意类型. 以下的样例创建了一个有序列 ...

  8. 《Android传感器高级编程》

    <Android传感器高级编程> 基本信息 原书名:Professional Android Sensor Programming 原出版社: Wrox 作者: (美)米内特(Greg M ...

  9. (五) 一起学 Unix 环境高级编程 (APUE) 之 进程环境

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

随机推荐

  1. fastadmin: layer.open 弹出层如何在表单提交之后自动关闭?

    需要在控制器对应的js文件中添加   Form.api.bindevent($("form[role=form]")); define(['jquery', 'bootstrap' ...

  2. ref:PHP反序列化漏洞成因及漏洞挖掘技巧与案例

    ref:https://www.anquanke.com/post/id/84922 PHP反序列化漏洞成因及漏洞挖掘技巧与案例 一.序列化和反序列化 序列化和反序列化的目的是使得程序间传输对象会更加 ...

  3. 洛谷P3444 [POI2006]ORK-Ploughing [枚举,贪心]

    题目传送门 ork 格式难调,题面就不放了. 分析: 一道偏难的贪心和枚举题.考试的时候是弃疗了...yyb巨佬已经讲的很详细了,推荐他的博客.这里小蒟蒻就只放代码了. Code: #include& ...

  4. Java多线程编程——volatile关键字

    (本篇主要内容摘自<Java多线程编程核心技术>) volatile关键字的主要作用是保证线程之间变量的可见性. package com.func; public class RunThr ...

  5. AM335x开发板与PC机虚拟机建立tftp文件传输

    1.AM335x开发板必须要支持以太网,而且在U-boot中要有完好的以太网驱动 因为开发板的储存介质为SD卡,所以在编译好的U-boot中并没有配置网络环境,为了不使每次上电都修改u-boot的网络 ...

  6. 绘制bitmap 全屏 安卓获取 屏幕大小

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 绘制bitmap 全屏 Rectf rectF = new RectF(0, 0, w, ...

  7. BZOJ1030 [JSOI2007]文本生成器(AC自动机)

    做到了AC自动机的题目,复习了一下AC自动机,学习了黄学长代码,这个题呢,我们可以模拟在AC自动机上的操作,dp数组f[i][j]表示前i个字符,我们在AC自动机上处在j号节点的方案数. 我们可以计算 ...

  8. poj 2342 && hdu 1520 树形dp

    题意:有n个人,接下来n行是n个人的价值,再接下来n行给出l,k说的是l的上司是k,这里注意l与k是不能同时出现的 链接:点我 dp[i][1] += dp[j][0], dp[i][0] += ma ...

  9. hihocoder 1522 : F1 Score

    题目链接   时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和他的小伙伴们一起写了很多代码.时间一久有些代码究竟是不是自己写的,小Hi也分辨不出来了. 于是他实现 ...

  10. linux基础命令学习 (七)压缩解压

    一.tar tar主要用来压缩和解压文件 语法: tar [主选项+辅选项] 文件或者目录 主选项: c 创建新的档案文件.如果用户想备份一个目录或是一些文件,就要选择这个选项.相当于打包. x 从档 ...