C#的位数组BitArray

引言:

使用这个BitArray是为了方便操作位,在操作IO卡或者运动卡的IO函数的时候,往往返回一个short值,然后需要转二进制后对其中的位进行操作,这个时候BitArray就方便了。



C#位数组

一、引言


如果我们着重处理一个以位为单位的数据时,就可以考虑使用位数组。例如在很多PCI的IO卡中涉及很多的I位的读取以此判断各个开关量的状态,或者设置继电器输出状态时,就会频繁用到位的操作。


这种情况C#提供的BitArray类和BitVectro32类就会起到很大的作用。本篇文章先讲解BitArray类。


二、BitArray类基础


1、BitArray类在命名空间System.Collections中可以找到。


2、BitArray类可以重新设置大小,BitVector32不会,它是固定32位的。


3、BitArray类是一个引用类型,它包含一个int数组,其中每32位使用一个

新整数,所以它的长度是可变的。例如如果BitArray存储的是63位的数 据,就会被存在两个int数据组成的数组中。因为63=32(int)+31(int)其中第二个int只使用了31位。如果BitArray存储的是65位的数据,就会被存在三个int数据组成的数组中,其中第三个int只使用了其中的1位,因为65=32(int)+32(int)+1(int)。


三、BitArray类常用方法

public sealed class BitArray : ICollection, IEnumerable, ICloneable
{
    public BitArray(BitArray bits); //用已有的BitArray给新的BitArray初始化
    
    public BitArray(bool[] values); //用布尔数组初始化
    
    public BitArray(byte[] bytes);  //用字节数组初始化
    
    public BitArray(int length);    //初始化并设置位数值,此值会在使用中自动增长
    
    public BitArray(int[] values);  //用int数组初始化
    
    public BitArray(int length, bool defaultValue); //初始化并设置默认值
    
    public int Count { get; }   //位数组中现存的位的个数
    
    public bool IsReadOnly { get; } //确定位数组是否只读

    public bool IsSynchronized { get; } //是否同步对此BitArray的操作,用在线程安全上
    
    public int Length { get; set; }   //位数组的位数

    public object SyncRoot { get; }
    
    public bool this[int index] { get; set; } //索引器,利用索引读位值
    
    public BitArray And(BitArray value);  //按位与

    public object Clone();  //创建BitArray 的浅表副本。
    
    public void CopyTo(Array array, int index);  //将BitArray拷贝到其他数组中
    
    public bool Get(int index);    //按下标读取位值

    public IEnumerator GetEnumerator(); //返回循环访问BitArray 的枚举数

    public BitArray Not();  //按位非

    public BitArray Or(BitArray value);  //按位或
    
    public void Set(int index, bool value);  //按位设置值
    
    public void SetAll(bool value); //设置所有位为指定值

    public BitArray Xor(BitArray value);  //按位异或
}

四、BitArray实例

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using System.Collections;
using System.Diagnostics;
using System.Collections.Specialized;
namespace TESTT
{
    class Program
    {
        static void DisplayBit(string tag,BitArray bits) //将位数组输出
        {
            if(tag!="")
                Console.Write(tag+":");
            foreach (bool b in bits)
            {
                Console.Write(b?1:0);  
            }
            Console.WriteLine();
        }
        static void Main(string[] args)
        {
            var bits = new BitArray(8);  //创建一个8位的位数组

            //设置全部位
            bits.SetAll(true);
            DisplayBit("设置全部为true后",bits);

            //设置指定位
            bits.Set(1,false);
            DisplayBit("设置下标1为false后",bits);

            //按索引器设置
            bits[5] = false;
            DisplayBit("设置下标5为false后", bits);

            //Not取反运算
            bits.Not();
            DisplayBit("bits取反后", bits);

            //更改位数组的长度
            bits.Length = 16;
            bits[9] = true;
            DisplayBit("设置下标9为false后", bits);

            //新建
            var bits2 = new BitArray(bits);
            bits2[0] = true;
            bits2[2] = true;
            bits2[4] = true;
            bits2[6] = true;
            bits2[8] = true;
            bits2[10] = true;
            bits2[12] = true;

            //Or或运算
            DisplayBit("", bits);
            Console.Write(" or");
            DisplayBit("", bits2);
            Console.Write("=");
            bits.Or(bits2);
            DisplayBit("", bits);

            //And运算
            DisplayBit("", bits);
            Console.Write(" and");
            DisplayBit("", bits2);
            Console.Write("=");
            bits.And(bits2);
            DisplayBit("", bits);

            //Xor运算
            DisplayBit("", bits);
            Console.Write(" xor");
            DisplayBit("", bits2);
            Console.Write("=");
            bits.Xor(bits2);
            DisplayBit("", bits);

            Console.ReadKey();
        }
    }
  
}




————————————————

版权声明:本文为CSDN博主「夏威夷紫菜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/weixin_40786497/article/details/104166424


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年5月    »
12345
6789101112
13141516171819
20212223242526
2728293031
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864