How memory is allocated in .Net application
-
ok i will try to find out right book for memory management. just tell me i have this code String s="Hello"; when the above line execute then what will happen? where the value "Hello" will be stored? in stack or heap? and where the memory location for "s" will be stored? thanks
tbhattacharjee
-
thanks for your time and explanation. would you mind to discuss briefly what is high frequency heap and how it is different than a normal heap? i hard the static class related info stored in high frequency heap but not sure is it true or not. why static class related info stored in heap? looking for your guidance.
tbhattacharjee
Seriously, we aren't here to do your thinking and research for you. I take it you have an interview soon. You cannot possibly cram in enough to bluff your way through based on random questions. You have been posting questions here long enough to have figured out that you need to learn the basics first. Richard has given you a great book to get started with. Beyond this, if you need to know things like the high frequency heap, then you need to learn how to use google and apply some critical thinking. Learning is your responsibility.
-
just tell me a books name which discuss in details how memory is allocated when we run our program. thanks
tbhattacharjee
Have a search through the MSDN magazine back issues. They have a lot of great information there.
-
Have a search through the MSDN magazine back issues. They have a lot of great information there.
if possible give me some good link from MSDN magazine which relevant for my question.
tbhattacharjee
-
I'm not going to answer your questions - but not because I'm nasty: because the questions are wrong! :laugh: The distinctions between stack and heap isn't as simple as you might think: and a variable in C# probably isn't what you think it is either - which is at the root of the "wrongness" of your questions. So: what is a variable? Simply put, a variable in a method is always allocated on the stack - but it's content may or may not be on the stack, depending on what type of data the variable refers to. If it's a
ValueType
, then the variable is allocated enough space to hold the whole value: andint
is aValueType
, and so is aPoint
. These are always the same size: you cannot extend the size of a ValueType in any way. If it's a reference type, then the variable always holds a reference to the actual data, rather than the data itself, and again the variable is a fixed size - only this time it is always either 32 bits or 64 bits depending on the environment your code is executing in. String is a reference type, so is any array. And that's important: because all reference values are allocated on the Heap: never, ever on the stack.int i = 6;
Integers are
ValueTypes
, so "i" is on the stack, and is the value of the integer - in this case 6.Button b = new Button();
Button is a reference type, so the actual data for the new instance is stored on the heap - but "b" is the variable and it is located on the stack, and contains a reference to the actual instance. But...that doesn't mean that all ValueType instances are on the stack - they aren't: they can be embedded in reference type instances:
public class MyClass
{
public int Value;
}
...
MyClass mc= new MyClass();
mc.Value = 6;MyClass is a reference type (all classes are reference types, all structs are value types) so the instance data is on the heap, and that includes the value type integer "Value" it contains. "mc" is on the stack and holds a reference to the heap based actual data. From here it starts to get very, very complicated - there is something called "boxing" to consider as well, where a stack based value is copied to the heap and passed as a reference - far too complicated for a little text box like this one! Get a c# book - they all explain this with pictures (which helps a lot) and when you've read it have a look at this:
5+ from me also. :)
-
Did you actually read the explanation that OriginalGriff posted, or the previous message that I wrote? A
string
is not a value type so its data will be stored on the heap. Its reference pointers
will be on the stack. If you want a simple explanation then read Charles Petzold's excellent .NET Book Zero[^].Nice Book.