|
Software2007 wrote: ...I want it to wok even if I left click and hold without actually moving the mouse...
If the mouse is supposed to move the gauge, how would the gauge move if the mouse wasn't? In other words, what is the gauge supposed to be doing if the mouse's button is clicked but the mouse is not moving?
"Old age is like a bank account. You withdraw later in life what you have deposited along the way." - Unknown
"Fireproof doesn't mean the fire will never come. It means when the fire comes that you will be able to withstand it." - Michael Simmons
|
|
|
|
|
fifth Edition
in Chapter 19, there is one note:
Note: It is important to realize that a single address space consists of one executable module and several DLL modules. Some of these modules can link to a static version of the C/ C++ run-time library, some of these modules might link to a DLL version of the C/C++ run-time library, and some of these modules (if not written in C/C++) might not require the C/ C++ run-time library at all. Many developers make a common mistake because they forget that several C/C++ run-time libraries can be present in a single address space. Examine the following code:
VOID EXEFunc() {
PVOID pv = DLLFunc();
// Access the storage pointed to by pv...
// Assumes that pv is in EXE's C/C++ run-time heap
free(pv);
}
PVOID DLLFunc() {
// Allocate block from DLL's C/C++ run-time heap
return(malloc(100));
}
So, what do you think? Does the preceding code work correctly? Is the block allocated by the DLL's function freed by the EXE's function? The answer is: maybe. The code shown does not give you enough information. If both the EXE and the DLL link to the DLL C/C++ run-time library, the code works just fine. However, if one or both of the modules link to the static C/C++ run-time library, the call to free fails. I have seen developers write code similar to this too many times, and it has burned them all.
===========================================================================
At first one thing the starup() function do is to initialize a heap used by malloc and free and low-level IO manipulation use in CRT, so when there is two copies CRT liberary in one process adress and there will be two heaps for two groups of malloc and free, and that one block memory grabed by malloc can only be freed by the very free() function in the same copy.
but what free() is?
in fact free()'s source code is like this:
void free(void *ptr)
{
struct mem_control_block *free;
free = ptr - sizeof(struct mem_control_block);
free->is_available = 1;
return;
}
every malloc()function return pointer to a block,however there are some bytes ahead the block conserved for system information, and this information is stored in a struct mem_control_block, so indeed the pointer malloc()function returned points to the byte after the mem_control_block.
struct mem_control_block {
int is_available; //a flag that specify whether this block can be used by any other application
int size; //the size of the block
};
finnally, it seems no error in these code:
VOID EXEFunc() {
PVOID pv = DLLFunc();
// Access the storage pointed to by pv...
// Assumes that pv is in EXE's C/C++ run-time heap
free(pv);
}
PVOID DLLFunc() {
// Allocate block from DLL's C/C++ run-time heap
return(malloc(100));
}
if the system doesn't allow a free() to free a block in heap of another copy of CRT, then how the system is able to forbid?????
Thanks for your help.
I'm struggle reading win via c/c++
Jack
modified on Friday, March 6, 2009 11:13 AM
|
|
|
|
|
Thanks for sharing the information! lol
He never answers anyone who replies to him. I've taken to calling him a retard, which is not fair to retards everywhere.-Christian Graus
|
|
|
|
|
Can somebody tell me what's wrong with the code?
I see no error in it, especially after i found out what free()is.
|
|
|
|
|
Send e-mail to get answer.
|
|
|
|
|
Hey man, thanks a lot, that's what I want.
But it is still lacking of more explanation in deep, any way, it's enough.
Any more clear in-depth explanation will be appreciated!
Jack
|
|
|
|
|
Send e-mail to get answer.
modified on Tuesday, March 10, 2009 10:16 AM
|
|
|
|
|
do you know what "ertain types of objects" are created using CRT heap? and why is a necessary?
Further, it seems unecessary to allocate a heap per CRT copy, in stead of let all CRTs use exe. heap, which is what heap meant to be.
So if the CRT heap exists, it must have a good reason. The reason lies on the data stored in the heap, what data and why stored there?
|
|
|
|
|
"d now there matching everything as if the object was created at the local heap" this is odd, then there is no need to allocate a heap for CRT.
is all this back-compatible consideration? the original CRT developers use this mechanism for some specific reason that is rarely used today but for compatible's sake Microsoft still maintain this feature?
|
|
|
|
|
Send e-mail to get answer.
modified on Tuesday, March 10, 2009 10:16 AM
|
|
|
|
|
Send e-mail to get answer.
modified on Tuesday, March 10, 2009 10:17 AM
|
|
|
|
|
Gorgeous! The best answer i have ever got since I have started asking for help in the internet! And I spend almost an hour to chew this answer. Thanks a ton! To make sure I've understood what you are saying,are you saying if each dll's referred CRT copy's version are the same, their would be no problem creating an object in this dll and deleting in another because they use the same allocator the same allocating algorithm??
|
|
|
|
|
Send e-mail to get answer.
|
|
|
|
|
Hehe, I got it.
And I'm waiting for the moment I have to allocate-deallocate memory across dll boundries in my job, before that I may be follow the rule: if you get a pointer to newly created memory by a dll, then you have to use a function in this dll and past this pointer as a parameter to it to delete( release indeed) the memory.
|
|
|
|
|
Send e-mail to get answer.
modified on Tuesday, March 10, 2009 10:17 AM
|
|
|
|
|
I read a lot of arctiles in heap management these days.
you can goole "free lists lookaside table filetype:ppt" and there a bunch of useful infomation. I find a serious problem:
1.all mallocs and frees in different versions of CRT of Windows call the same RtlAllocateHeap(), and RtlFreeHeap(), and all infomation needed by RtlAllocateHeap,and AtlFreeHeap() was builded by ntoskrnl.exe. It seems to me that malloc and free don't need to interact with CRT.
What specific info is contained in CRT, rather than process management field(PEB or sth.)?
|
|
|
|
|
you can see:
Dynamic Memory Management.ppt for more info.
|
|
|
|
|
"A heap descriptor"?
you mean "heap structures"? which contain Freelists, Lookaside Lists and the like and which reside in the front of A heap?
Does CRT change the content of heap descriptor directorly or it was edited while inside RltHeapAllocate or RltFreeHeap? It seems to me the latter one is safer and more reasonable.
The second question, yes, the debug and release version does contain different info of heap, because debug version want to provide more info such as heap memory leak, heap memory overflows, etc.
What's the main differneces between each release versions?
I discover one, which you can see in page 32 in XPSP2 Heap Exploitation.ppt( you can find this on internet, or i can send you by email)
And I want to make sure that: chances are that when one copy of CRT is mapped to process memory address in DLLMain(), its own heap can be initialized. Can this happens because I saw this opinion in some articles. But you are saying there are only one heap-the default heap for each version of CRT to malloc and free. Are you sure with what you are saying?
|
|
|
|
|
Shall we talk on MSN?
my MSN is dingxiaofenguni@gmail.com
|
|
|
|
|
as you know, we have to create a dynamic splitter window within CFramWnd::OnCreateClient. In this way, we have one or two splitter box as soon as the application is executed! But I want to create the splitter window using a command from the manu bar. Is it possible? Why if not?
Thank you masters!
|
|
|
|
|
You keep reposting this yet you never responded to the first reply you got. Stop doing that PLEEEEZZZZ, it's urgent.
|
|
|
|
|
Dear fellow programmers!
I would like to retrieve an array of POINTs describing the edge of a existing region. There is a CRgn function CreatePolygonRgn() which takes an array of POINTs and creates a CRgn. Is there a function to retrieve the POINTs again?
Please help: I've used up at least a whole redwood on google searches.
Thanks,
Jonnie
|
|
|
|
|
My guess:
CRgn::GetRegionData->RGNDATA->RGNDATAHEADER
You can get the points from rcbound from the below structure
typedef struct _RGNDATAHEADER {
DWORD dwSize;
DWORD iType;
DWORD nCount;
DWORD nRgnSize;
RECT rcBound;
} RGNDATAHEADER, *PRGNDATAHEADER;
MSDN[^]
ADDED:
oops, there's a better function:
CRgn::GetRgnBox[^]
He never answers anyone who replies to him. I've taken to calling him a retard, which is not fair to retards everywhere.-Christian Graus
|
|
|
|
|
Thank you VuNic for the quick reply. If my CRgn is not a rectangle, however, this will not solve my problem.
I suppose I could navigate through all RECTs in the RGNDATA struct, creating one POINT for each corner. However, 1) I was hoping there was a function which does this for me and 2) I suspect it is not as easy as it sounds (what if it's a complex region?).
So, I am still hoping for a solution, e.g. a GetPointsFromRegion(CRgn* pRgn, POINT* pPoints, BYTE* pTypes, int& nCount) function.
Greetings,
Jonnie
modified on Friday, March 6, 2009 10:18 AM
|
|
|
|
|
I found these "keywords"
//--- copy points to original structure ---
::CopyMemory((LPBYTE)dwOffsetAddr, lpPointsFx, nPtBufSize);
Here:
http://www.codeproject.com/KB/graphics/TTPolygon.aspx?display=PrintAll[^]
You may check that one. I'm not very sure though.
He never answers anyone who replies to him. I've taken to calling him a retard, which is not fair to retards everywhere.-Christian Graus
|
|
|
|