Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 41

Как инициализировать BitArray размером более 32int

10.11.2015, 16:46. Показов 2391. Ответов 8

Студворк — интернет-сервис помощи студентам
Вот такая проблема, необходим массив битов размером n =128 * 10^9 , в идеале.
Но .NET предлагает только BitArray(Int32).
Может существует отдельная библиотека которая это реализует, или средствами NET тоже можно это сделать, только я не в курсе=)

Заранее спасибо.

ПС. Памяти у меня хватит =)
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.11.2015, 16:46
Ответы с готовыми решениями:

Как написать процедуру выводящую файлы размером более 1мб
помогите пожалуйста с задачей,сам пытался разобраться, но никак не получается, нужно написать процедуру, которая будет распечатывать из...

Рассматривая массивы как конечные множества целых чисел, построить массив размером не более 2n
Даны значения двух целочисленных массивов x и y размером n. Рассматривая массивы как конечные множества целых чисел, построить массив...

Есть ли возможность более элегантно инициализировать массив data?
Доброе утро! Назрел следующий вопрос. На этот раз он связан с созданием конструктора с переменным количеством параметров. Есть такой код: ...

8
 Аватар для Konctantin
970 / 773 / 171
Регистрация: 12.04.2009
Сообщений: 1,700
10.11.2015, 17:25
Используйте System.Collections.BitArray
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 41
10.11.2015, 17:40  [ТС]
Так как бы в этом и проблема, там максимальное количество элементов 32 бита (то есть 2 миллиарда всего)
Там есть BitArray(Int32) а мне бы BitArray(Int64)
0
484 / 397 / 68
Регистрация: 14.02.2014
Сообщений: 1,930
10.11.2015, 17:43
Konctantin, надо быть внимательнее читая вопрос

Andrean4ik, если навскидку - на шарпе без извращений ничего на ум не приходит. Как вариант - написать на плюсах библиотеку, использующую bitset и вызывать её из шарповской программы. Засада в том, что 64 битный размер этот класс может иметь только на 64 разрядных ОС, в 32 разрядных - максимальный размер того-же uint32.

Добавлено через 1 минуту
сцылко на описание класса
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 41
10.11.2015, 17:51  [ТС]
aquaMakc, Не беда, у меня 64 бит ОС, и приложение, так сказать, для исследования пишется.
0
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,569
10.11.2015, 18:49
Лучший ответ Сообщение было отмечено Andrean4ik как решение

Решение

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
    class CustomBitArray
    {
        private ulong[] _bits;
        private ulong _count;
        private ulong _blocks;
 
        public CustomBitArray(ulong count)
        {
            _count = count;
 
            _blocks = (_count + 63) / 64;
 
            _bits = new ulong[_blocks];
        }
 
        public ulong Count
        {
            get { return _count; }
        }
 
        public unsafe bool this[ulong index]
        {
            get
            {
                if (index >= _count)
                    throw new ArgumentOutOfRangeException("index");
                fixed (ulong* ptr = _bits)
                {
                    return (((byte*)ptr)[index >> 3] & (byte)(1 << (int)(index & 0x7))) != 0;
                }
            }
            set
            {
                if (index >= _count)
                    throw new ArgumentOutOfRangeException("index");
                fixed (ulong* ptr = _bits)
                {
                    ((byte*)ptr)[index >> 3] |= (byte)(1 << (int)(index & 0x7));
                }
            }
        }
    }
Написал на коленке, вроде работает, требует /unsafe.

C#
1
2
3
4
5
6
CustomBitArray ab = new CustomBitArray(5000000);
 
ab[0] = true;
ab[10] = true;
ab[999998] = true;
ab[999999] = true;
1
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 41
10.11.2015, 19:01  [ТС]
Someone007, Спасибо, буду пробовать =)
0
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,569
10.11.2015, 20:28
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
    class CustomBitArray
    {
        private ulong[] _bits;
        private ulong _count;
 
        public CustomBitArray(ulong count)
        {
            _count = count;
 
            ulong _blocks = (_count + 63) / 64;
 
            _bits = new ulong[_blocks];
        }
 
        public ulong Count
        {
            get { return _count; }
        }
 
        public bool this[ulong index]
        {
            get
            {
                if (index >= _count)
                    throw new ArgumentOutOfRangeException("index");
 
                return (_bits[index >> 3 >> 3] & (1UL << (int)(index & 0x7F) << 64)) != 0;
            }
            set
            {
                if (index >= _count)
                    throw new ArgumentOutOfRangeException("index");
 
                _bits[index >> 3 >> 3] |= (1UL << (int)(index & 0x7F) << 64);
            }
        }
    }
Тоже самое без использования unsafe.
Создать масив размером 128000000000 бит у меня не получилось. Максимум что создалось, это примерно 17120000000 бит.
1
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 41
10.11.2015, 20:51  [ТС]
У меня все вышло =) Спасибо огромное =)
Someone007, надо в файле App.config прописать снятие ограничения на использование памяти:
https://msdn.microsoft.com/en-... .110).aspx
и не забыть в настойках проекта выставить: проект > сборка > конечная платформа > x64
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.11.2015, 20:51
Помогаю со студенческими работами здесь

Как работает BitArray?
Вопрос такой, есть много операций с битами, именно с битами, нашел такую структуру BitArray. Не пойму как она работает. Как я понимаю...

Как найти битовую сигнатуру в BitArray?
Друзья, добрый день! Есть последовательность &quot;битов&quot; в BitArray (берется из файла &gt;100M) И есть набор сигнатур, они могут быть...

Построить массив z размером не более 2n
Помогите решить с помощью рекурсии Даны значения двух целочисленных массивов х и у размером n. Рассматривая массивы как конечные...

Отсортировать содержимое файла размером более 5 ГБ
Здравствуйте! Столкнулся с проблемой построчной сортировки большого файла. Кто-нибудь может помочь с идеями? И хочется без вызовов утилит...

Работа с матрицей размером более 2 Гбайт
Скажите пожалуйста. Я понял, Delphi 6 не может работать с матрицей более 2 Гбайт. Запускаю прог.Delphi 6 матрица j более 2 Гбайт. Есть...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru