Форум программистов, компьютерный форум, киберфорум
bedvit
Войти
Регистрация
Восстановить пароль
Рейтинг: 3.20. Голосов: 5.

Variant Serialization and Deserialization

Запись от bedvit размещена 25.01.2024 в 17:08
Обновил(-а) bedvit 25.01.2024 в 17:27

Cериализация и десериализация типа данных Variant, используемый в COM, VB, VBA, C++, Python и других поддерживающих СОМ языков

Реализация в СОМ. Реализация для XLL как функция COM.DLL
Часть библиотеки BedvitCOM
Поддерживаются базовые типы и массивы. Объекты не сериализуются.
В некоторой степени - аналог CComVariant::ReadFromStream и CComVariant::WriteToStream


Функции:
VARIANT byteArrayOutRetval = VariantSerialization(VARIANT variantIn)

VARIANT variantOut= VariantDeserialization(VARIANT byteArrayOutRetval)

Параметры функции:
1. variantIn/variantOut- входящий/получаемый VARIANT - значение или массив значений
2. byteArrayOutRetval - массив байтов



Особенности:
1. Cериализация в байтовый массив
2. Размер массива не может превышать 2^32 элементов (около 4Гбайт). Это ограничение самого COM - массива. В С++ (в другом контейнере) сохранял файлы боле 4,5 Гб.
3. Реализован похожий механизм (shared string table), как и в Excel, для оптимизации размера одинаковых строк.


Пример использования:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Sub TestVariantSerialization()     
 
    'Dim bVBA As New BedvitCOM.VBA 'раннее связывание     
    Dim bVBA As Object: Set bVBA = CreateObject("BedvitCOM.VBA") 'позднее связывание     
    Dim t, arr, byteArr     
     
    Range("A:B").value2 = "Tst Srl ёя"        
  
    t = Timer         
    byteArr = bVBA.VariantSerialization(Range("A:B").value2)         
    arr = bVBA.VariantDeserialization(byteArr)     
    Debug.Print "VariantSerialization+VariantDeserialization " & Timer - t & " s."     
 
    Range("D:E").value2 = arr     
 
End Sub
Размещено в Без категории
Показов 813 Комментарии 3
Всего комментариев 3
Комментарии
  1. Старый комментарий
    Аватар для AlexProgramm
    Эх, в java типа данных Variant нету
    Запись от AlexProgramm размещена 28.01.2024 в 20:49 AlexProgramm вне форума
  2. Старый комментарий
    Аватар для bedvit
    Насколько я понял, в Java не проблема использовать СОМ.
    https://www.codeguru.com/java/... tegration/
    Запись от bedvit размещена 29.01.2024 в 08:57 bedvit вне форума
  3. Старый комментарий
    Аватар для AlexProgramm
    Будем знать!
    Запись от AlexProgramm размещена 29.01.2024 в 23:36 AlexProgramm вне форума
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru