I'm not heavy into the internals of VB, but here is my take. The tag property is a string, so an object always has the overhead of an empty string even when the tag is empty. This is a pointer which is a long integer (4 bytes). The pointer contains the value zero when the string (tag) has not been given a value.<br><br>On the other hand, if a string is created in code to hold the data, it will be the size of the string, plus the overhead (the 4 byte pointer), so it would seem that using the tag would save 4 bytes for the pointer because those bytes are already allocated when the object is created.<br><br>Since VB holds the length of strings, rather than using a null terminator as in C, there is probably more overhead for that as well (probably 4 more bytes). Again, this space is probably already allocated in the object and just wasted if tag is not used, so it may save 8 bytes or more to use the tag.<br><br>This is all based on best guess. Any other ideas?
thanx i know 8 bytes isnt gunna make a machine start sprinting but if programmers start thinking like they did 30 years ago about waranting every last byte of RAM usage i can almost guarantee a major step-up in alaround performance.
i had this teacher who used to tell us avout the punch cards he worked with and how every last bit was used and maximized to its full potential. since system resources were at a premium.
programmers today are at such an ease of use of big data types
that saving a byte or a megabytle is too much of a hassle ahh!
I am one of those who started with the IBM punch cards. Believe me we didn't do all that work to squeeze the bytes from any noble perspective. It was just plain [red]NECSSSARY[/red]. Even some of the first generation of IBM PC with 8K (bytes) of memory and the 4.77 MHz clocks were a luxury compared to some of my early programming environments.
Yes, I have agonized over how to save 8 bytes of memory - even to the extent of re-writing assebly language code to save the instruction space. Als, many other trails and tribulations over both memory and execution speed. But NEVER because "... it just seemed right ...".
Try to keep some perspective here, we did it either because we HAD to (from the machine resources perspective) or the cost of that hardware was a LOT more than our salary! Try to compute the "cost" of the "8 Bytes" of memory - in your computer today, and convert it to how long it takes you to expend the same $$$ using just your salary. If you can honestly say it is worth it, I want a job there!!!!!!!
MichaelRed
There is never time to do it right but there is always time to do it over
This site uses cookies to help personalise content, tailor your experience and to keep you logged in if you register.
By continuing to use this site, you are consenting to our use of cookies.