 cgibson
		
			cgibson
		
		
		
		
		
		
		
		
	
			08-26-2025 08:42 AM
I have this LabVIEW 2017 program that manages log files. The log files are zipped TDMS files. One of the features of the program is to convert from TDMS to a flat CSV file.
When this feature is run, the memory as reported by the Windows Task Manager increases by around 100 megabytes. If I do it again, I get another 10 megabytes on top of that. My concern is that if this keeps going I will eventually run out of memory. This program is meant to run 24/7 managing log files created by another application. The conversion is not done all the time, which is probably why it hasn't been a problem yet.
I have already looked for leaking file references, but the code closes the references it uses. I tried adding a TDMS flush right before closing the TDMS file. It didn't help.
I have read that TDMS uses memory for advanced indexing, but it seems like this would be deallocated when the reference was closed.
I have attached the convert function. The calling code runs this in a loop, once each for all the files to be converted. The String output is used to update a status on the program's front panel.
 altenbach
		
			altenbach
		
		
		 
		
		
		
		
		
	
			08-26-2025 11:53 AM
08-26-2025 01:09 PM
The program uses a state machine design. The unzip happens in a prior state.
No. I build this as an application and am watching the memory usage of that process.
A typical file is around 5 megabyte once uncompressed.
The files I am working with have proprietary data in them. I will have to generate a dummy file of similar size.
08-26-2025 03:34 PM
Here is a dummy zipped TDMS file.
I have confirmed that if I run this through my application I get the bump in memory usage.
 Andrey_Dmitriev
		
			Andrey_Dmitriev
		
		
		
		
		
		
		
		
	
			08-27-2025 02:24 AM - edited 08-27-2025 02:35 AM
@cgibson wrote:
I have this LabVIEW 2017 program that manages log files. The log files are zipped TDMS files. One of the features of the program is to convert from TDMS to a flat CSV file.
When this feature is run, the memory as reported by the Windows Task Manager increases by around 100 megabytes. If I do it again, I get another 10 megabytes on top of that. My concern is that if this keeps going
You should keep in mind that LabVIEW has its own smart Memory Manager on top of the low-level Windows memory allocators. This means it will allocate memory in advance and keep it allocated for performance reasons. You don’t need to worry too much about additional allocations during single runs. To check for memory leakages, run the code continuously in a loop as an stress test over a long period and monitor it. After a certain number of iterations, the memory usage will stabilize and will not increase further. I don’t see any memory leaks in the given code — it remains stable at around 450 MB.
Under certain rare conditions, when working with very large data blocks, you may encounter memory fragmentation issues. The simplest way to avoid this problem is to use a 64-bit environment.