Solved

Insufficient Memory Error

Posted on 2004-09-24
9
374 Views
Last Modified: 2010-04-05
I have a place in my program in which I have an IBDataSet. I Have a routine in which goes until end of file. Like this:

while not DataSet.eof do
begin
 // I commented everything he was doing it here to see
 //if the error stops, but it didn´t.
DataSet.Next;
end;

So the only thing is doing is going through the Data. And when I try to do something else after this routine it gives give the error: "Insufficient Memory" What can it be ? Thanx
0
Comment
Question by:fabyola
  • 3
  • 2
  • 2
  • +1
9 Comments
 
LVL 12

Expert Comment

by:esoftbg
ID: 12147731
Have your DataSet assigned events as:
  DataSetBeforePost(DataSet: TDataSet);
or
  DataSetAfterPost(DataSet: TDataSet);
It is possible the reason about the "Insufficient Memory" to be there ....
Just try to guess ....
0
 
LVL 12

Expert Comment

by:esoftbg
ID: 12149448
Please ignore my above comment (It was after midnight bulgarian time and I was very tired):

Has your DataSet assigned events as:
procedure TForm1.DataSetBeforeScroll(DataSet: TDataSet);
begin
//........
end;
or
procedure TForm1.DataSetAfterScroll(DataSet: TDataSet);
begin
//........
end;

It is possible the reason about the "Insufficient Memory" to be there ....
Just try to guess ....
0
 
LVL 5

Expert Comment

by:Voodooman
ID: 12149819
Hi - comment only

Just an idea - lots of data applications write temp files trasparently - is your temp directory full?

Or is your temp directory on a drive with only small free space?

Also - remember that Error Messages are not to be relied on - the message is just what the programmer thought would be most appropriate in the circumstance - the actual error could be something completely different!

Voodooman

0
 
LVL 12

Expert Comment

by:esoftbg
ID: 12149845
Ofcourse the reason for the "Insufficient Memory" could be outside your application: some spyware or some virus ....
0
Highfive Gives IT Their Time Back

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

 

Author Comment

by:fabyola
ID: 12158881
No it´s not a spyware or some virus because it happens on any computer. And it´s not using a Temp directory. And it also doesn´t have nothing on afterscroll or beforescroll events.
0
 
LVL 22

Expert Comment

by:Ferruccio Accalai
ID: 12160275
what is important to know is the Exception Type
Is it an EIBError? Or just an  EAccessViolation? That's important to get a point of start....
Then also note that if you've called TIBDataset.Prepare before the loop then you have to reset the satus calling Unprepare (releasing memory). But everything said depends on the status of the IBDataset...
0
 

Author Comment

by:fabyola
ID: 12198727
I was a simple error message. It wasn´t an "EIBError" neither an "EAccessViolation" error. I also didn´t call TIBDataset.prepare. I only did an TIBDataset.Open; before doing the loop. Can it be it´s beause it´s too much data ?
0
 
LVL 22

Assisted Solution

by:Ferruccio Accalai
Ferruccio Accalai earned 62 total points
ID: 12199049
Just doing scroll to EOF isn't a believable reason for such kind of error even if there are lot of datas. What about the object (if you are using it)? Are there some datacontrols llinked like grids or edits? Or some other dataset in Master-detail?
0
 
LVL 5

Accepted Solution

by:
Voodooman earned 63 total points
ID: 12199259

Hi

According to this http://www.better-office.com/Deutsch/Produkte/Borland/InterBase/InterBase_Community/InterBase_Com_Aktuell/InterBase_Com_Aktuell__minus__25_Jul__brO_1_brC_.htm

These IBX datasets have ememory allocation problems.

Take a look at the above it might help explain and has some suggestions.

Of course you could actually be running out of memory and then out of paging space.  Looping thru recs is one of the most inefficient things you can do with a recordset.  If you were actually paging to disk you would probably not even notice if you were looping thru the recs.

What are you doing in the loop (I hope you are not putting the recs into arrays for instance - I have seen this done) - are you doing anything that would diminish resources?

Voodooman
0

Featured Post

Better Security Awareness With Threat Intelligence

See how one of the leading financial services organizations uses Recorded Future as part of a holistic threat intelligence program to promote security awareness and proactively and efficiently identify threats.

Join & Write a Comment

Suggested Solutions

Introduction The parallel port is a very commonly known port, it was widely used to connect a printer to the PC, if you look at the back of your computer, for those who don't have newer computers, there will be a port with 25 pins and a small print…
In my programming career I have only very rarely run into situations where operator overloading would be of any use in my work.  Normally those situations involved math with either overly large numbers (hundreds of thousands of digits or accuracy re…
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…
This tutorial demonstrates a quick way of adding group price to multiple Magento products.

762 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now