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

Вниз

Память и указатели   Найти похожие ветки 

 
TUser ©   (2004-09-10 16:10) [0]

Как будет размещена в памяти такая структура

PLock = ^TLock;
TLock = record
   Next:PLock;
   FirstFound:PFound; // Это некий указатель, неважно какой
   StrandsAndLoops:array [0..5] of TStrandOrLoop;
   Num:integer;
   end;

где

   TStrandOrLoop = record
      Chain:char;
      S, E:integer;
      Sequence:string;
      end;

Создаю это дело через New, вроде бы все должно работать. И все работает, но на таком вот участке кода получаю AV

var pl1,pl:PLock;

for i:=0 to 5 do begin
  pl1^.StrandsAndLoops[i].Chain:=pl^.StrandsAndLoops[i].Chain;
  pl1^.StrandsAndLoops[i].S:=pl^.StrandsAndLoops[i].S;
  pl1^.StrandsAndLoops[i].E:=pl^.StrandsAndLoops[i].E;
  pl1^.StrandsAndLoops[i].Sequence:=pl^.StrandsAndLoops[i].Sequence;
  end;

Аналогично будет AV, если написать

for i:=0 to 5 do
  pl1^.StrandsAndLoops[i]:=pl^.StrandsAndLoops[i];

Ctrl-F7 на pl^ показывает полную ерунду, которая никак не соотвествует тем значениям, которые присвоены этому pl. То, что изначально они присвоены правильно - в этом я точно уверен. Но складывается впечатление, что в этом месте pl указывает совсем непонятно куда, где лежит какая-то лажа.
В чем тут может быть дело.

PS. Понимаю, что трудно ответить на такой вопрос, не перекопав исходники всего проекта, но вдруг ...


 
Digitman ©   (2004-09-10 16:14) [1]


> И все работает


а что, собссно, работает-то ? New() ?


 
Ega23 ©   (2004-09-10 16:17) [2]

New и pl и pl1 должно быть.


 
TUser ©   (2004-09-10 16:18) [3]

New работает. А вот когда я начинаю переписывать ин-цию из одного рекорда в другой, то получаю av. Хотя, повторюсь, данные точно загружены и память выделена. Это точно.
Т.е. указатель указывает куда-то куда ему хочется, а не куда я сказал.

Собственно главный вопрос, в котором я начал сомневаться - есть ли какие-нибудь особенности хранения такой записи в памяти. Учитывая, что там массив (статический) и строки. Хотя, раньше я с такими штуками работал, особых проблем не помню.


 
TUser ©   (2004-09-10 16:18) [4]

Да, new для всех есть.


 
Digitman ©   (2004-09-10 16:21) [5]


> New работает


и для pl и для pl1  вызвана она ? или облажался и не заметил ?


 
TUser ©   (2004-09-10 16:23) [6]

См. [4]


 
Digitman ©   (2004-09-10 16:28) [7]


> TUser ©   (10.09.04 16:23) [6]


а по-моему ты горбатого лепишь) ... что-то здесь не так как ты изложил ...


 
Ega23 ©   (2004-09-10 16:36) [8]

Если всё так, как ты говоришь, то должно работать.
Давай весь код.


 
TUser ©   (2004-09-10 18:19) [9]


> Давай весь код.

Зачем? 3-4 десятка страниц, где память в одном месте выделяется, а через 25 страниц используется? Вряд ли ко-то добровольно будет это читать.
Просто начали одолевать меня сомнения - нет ли чего-то такого чего я не знаю, что мешает правильной работе с такими рекордами. Но, видимо, нет. Так что всем спасибо.


 
Arm79   (2004-09-10 21:09) [10]

TStrandOrLoop = record
     Chain:char;
     S, E:integer;
     Sequence:string; - ShortString
     end;


 
Mim1 ©   (2004-09-10 21:57) [11]


> [10] Arm79   (10.09.04 21:09)

Ну ну.


 
wnew ©   (2004-09-10 22:18) [12]

Mim1 ©   (10.09.04 21:57) [11]
Обоснуйте, что значит "Ну ну".

По моему Arm79 (10.09.04 21:09)[10] правильно считает.


 
Mim1 ©   (2004-09-13 10:14) [13]


> [12] wnew ©   (10.09.04 22:18)


А по моему нет, проблемма со string, shortstring из другой оперы. Использование string  (ansistring) в динамичесих массивах, списках и подобных вещах у меня проблемм не вызывает. Единственное ограничение которое приходит мне в голову, это то что надо память выделять при помощи new, и освобождать при помощи dispose.


 
PVOzerski ©   (2004-09-13 10:22) [14]

Копаться лень мне... Навскидку: попробуй после new забить нулями StrandsAndLoops (или StrandsAndLoops[0].Sequence, ... , StrandsAndLoops[5].Sequence) через FillChar.


 
evvcom ©   (2004-09-13 10:51) [15]


> Ctrl-F7 на pl^ показывает полную ерунду, которая никак не
> соотвествует тем значениям, которые присвоены этому pl

Помести pl^ по Ctrl-F5 и прошагай от присвоения до AV. Где-нибудь и заметишь изменение pl^. А так что еще предложить? Не анализировать же действительно нам 3-4 листа кода без отладчика!


 
PVOzerski ©   (2004-09-13 10:57) [16]

Я сейчас приведенный код в D3 прогнал - никакого AV. Правда, сделал FirstFound:pointer; но это явно не при чем.


 
Arm79   (2004-09-13 11:48) [17]

Mim1 ©   (13.09.04 10:14) [13]
Вообще то именно это я и имел в виду. Если использовать динамическое выделение памяти, то надо не забыть использовать его и для string. А использование ShortString позволяет избежать этого. Вот и все, собственно говоря.

PS Я лично стараюсь использовать не New/Dispose, а GetMem(AllocMem)/FreeMem


 
TUser ©   (2004-09-13 11:54) [18]

О! Все обсуждаете. Всем спасибо.
Баг я в субботу нашел, и жил он совсем не здесь.


 
Mim1 ©   (2004-09-14 17:25) [19]


>  [17] Arm79   (13.09.04 11:48)



> Если использовать динамическое выделение памяти, то надо
> не забыть использовать его и для string.


Не всегда.


> Я лично стараюсь использовать не New/Dispose, а GetMem(AllocMem)/FreeMem


Вот из зря, первые ничуть не лучше чем вторые, они просто разные.
Вот изза того что вы исполдьзуете getmem вам и приходится использовать shortstring в одних местая перерасходуя память а в других ограничивая размер строки и подобные вещи (типа pchar).
К стати вам про GetMem delphi не говорит всякими, варнингами, например что этого в дот нет не будет?


> [18] TUser ©   (13.09.04 11:54)
> О! Все обсуждаете.

В споре рождается истина. :) Или в вине. :)


 
Arm79   (2004-09-14 22:47) [20]

Mim1 ©   (14.09.04 17:25) [19]

Нет, мне Delphi ничего по этому поводу не говорит.
Про Дот.Нет не спорю, может так оно и есть, не работал.

Мне не приходиться использовать ShortString - я сам определяю степень допустимости его применения. Никаких ограничений по этому поводу у меня нет. Иногда использую в DLL. И я никогда не слышал о том, что размер Pchar надо ограничивать. Наверное, мало знаю.

Про string согласен, не всегда надо выделять под него вручную память, но при записи в файл, по моему, это делать просто необходимо.

Ин вино веритас!!! :-))

Это все мое субъективное мнение. Буду рад, если кто поправит.


 
Mim1 ©   (2004-09-15 15:05) [21]

:)
И так, разбор полетов.
1) не понимаю зачем вы DLL и файлы вспомнили, да это смежные темы, но к текущему обсуждению отношения не имеет.
2) вы меня не внимательно читали, или просто не поняли.
 а) при работе  с shortstring имееться ограничение на макс размер и перерерсаход памяти в общем случае.
 б) при работе с pchar на размер ограничений нет кроме тех что вы придумаете сами, однако для работы с нми надо самостоятельно выделять память.
По сравнению с string эти два типа данных ИМХО проигрывают, однако вым приходится их использовать если вы брезгуете использованием new и dispose.

На сем предлагаю закончить обсуждение.



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

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

Наверх




Память: 0.5 MB
Время: 0.038 c
1-1095152652
Ricko
2004-09-14 13:04
2004.10.03
Unicode


14-1095409956
wal
2004-09-17 12:32
2004.10.03
Cпециальные символы. Происхождение.


6-1090467422
v2
2004-07-22 07:37
2004.10.03
Indy TCP CLient не соединяется с прокси-сервером


4-1093321751
Baloo
2004-08-24 08:29
2004.10.03
Координаты каретки в чужом приложении


11-1081013613
mehos
2004-04-03 21:33
2004.10.03
Ширина выводимой меню, при OwnerDraw=true





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский