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

Вниз

Ошибка при обращении со строками   Найти похожие ветки 

 
capkoh ©   (2006-01-04 20:11) [0]

Написал код вставки текста из буфера обмена. В этом коде на последней строке происходит ошибка. Это связано с тем что что-то не в порядке с обрашением с памятью и\или обращением со строками.

Если использовать код для малых кусков текста, то все в порядке. Однако, при больших текстах что-то в WideCharToMultiByte ломается. Никак не пойму что. У кого-нибудь есть идеи как проконтролировать длину строки? И какая она максимальная? На сколько я знаю - 4ГБ...

procedure TSomeEdit.GetBuffer(Format: word; var Buffer : PWideString);
var
 temp : WideString;
 Data: THandle;
begin
 OpenClipboard(Handle);
 Data := GetClipboardData(Format);
 try
   if Data <> 0 then
     begin
       temp := PWideChar(GlobalLock(Data));
       Buffer := PWideString(temp);
     end
   else
     Buffer := 0;
 finally
   if Data <> 0 then GlobalUnlock(Data);
   CloseClipboard;
 end;
end;

Вызов:

ws : TWideString;

GetBuffer(CF_UNICODETEXT, PWideString(ws));
n := WideCharToMultiByte(CodePage, 0, PWideChar(ws), -1, 0, 0, 0, 0);


 
Гаврила ©   (2006-01-05 00:31) [1]


>temp := PWideChar(GlobalLock(Data));
>        Buffer := PWideString(temp);


temp - локальная переменная, которая будет автоматически освобождена компилятором при выходе из
процедуры GetBuffer().
соответственно, в переменной
var Buffer : PWideString
ты запоминаешь ссылку на ужзе освобожденный участок памяти


 
capkoh ©   (2006-01-05 16:30) [2]

Спасибо, починил!



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

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

Наверх




Память: 0.47 MB
Время: 0.047 c
3-1133785755
Kerk
2005-12-05 15:29
2006.02.05
Excel. Чувствую, что торможу


3-1133529056
mpokemonov
2005-12-02 16:10
2006.02.05
Записи в таблицы


15-1137108846
Quattro
2006-01-13 02:34
2006.02.05
KaZaa


1-1135873231
френк
2005-12-29 19:20
2006.02.05
Сортировка TListView по колонкам


3-1133506840
skulll
2005-12-02 10:00
2006.02.05
Помогите подключится к MSSQL через ADO