Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.03.04;
Скачать: CL | DM;

Вниз

Смысл типа TVarBytesField   Найти похожие ветки 

 
programmer1 ©   (2002-02-12 10:22) [0]

Уважаемые коллеги, скажите, пожалуйста, что означает тип поля TVarBytesField, какого типа данные можно в нем хранить. В книге Фаронова написано:
"Поле TVarBytesField содержит произвольное значение длиной до 65535 байт. Текущая длина хранится в первых двух байтах и может быть получена с помощью свойства Datasize"
Поясните мне, пожалуйста, смысл этих магических слов!


 
Digitman (M) ©   (2002-02-12 12:24) [1]

TVarBytesField - класс, инкапсулирующий ф-ции управления полями объектов БД, предназначенными для хранения данных переменной длины, не превышающей 64кб. В полях такого типа физически хранятся не только сами данные, но и инф-ция о реальном их размере. Вот этот самый реальный размер и представлен св-вом Datasize.
Когда в поле такого типа записываются некие данные (в виде блока последовательных байт), то сначала записывается размер блока (те самые первые первые 2 байта), а затем записывается собственно блок.
Когда из поля такого типа считываются ранее записанные туда данные, то сначала считываются первые 2 байта (их значение, интерпретируемое как WORD, становятся зн-ем св-ва TVarBytesField.Datasize), а затем в выделенный буфер размером в Datasize + 2 считываются данные, включая первые служебные 2 байта. Т.е. в буфере данных такого поля по смещению +0 хранится слово, значение которого информирует о размере собственно данных, по смещению +2 - собственно блок данных указанного по смещению +0 размера (в байтах).


 
Programmer1 ©   (2002-02-14 11:26) [2]

Спасибо за полный ответ.



Страницы: 1 вся ветка

Текущий архив: 2002.03.04;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.007 c
6-9259
Yuri Btr
2001-12-18 10:36
2002.03.04
Тест порта


1-9231
Shoo
2002-02-15 16:54
2002.03.04
Констант-массив


7-9318
DenKop
2001-11-26 21:20
2002.03.04
Рабочий стол.


1-9187
Termik
2002-02-14 15:14
2002.03.04
Отладчик Delphi


1-9143
Hewlping
2002-02-17 19:03
2002.03.04
Помогите!