Solved

VB.Net WinForms Application Main Form Loading with Splash Screen

Posted on 2015-01-27
3
54 Views
Last Modified: 2016-07-12
I have a VB.NET WinForms application with a splash screen containing a progress bar which I can successfully update during the Load event of the Main Form (formMain).  This was accomplished by reviewing the following article:

http://www.experts-exchange.com/Programming/Languages/.NET/Visual_Basic.NET/A_3671-Updating-a-Splash-Screen-with-Loading-Progress-in-a-VB-Net-WinForms-Application.html

How can I determine what is occurring in my application prior to the formMain_Load() event being triggered?  The splash screen is visible and active for 15 seconds prior to reaching the breakpoint at the first line of the MyBase.Load event of formMain.  Afterwards, everything is as expected.  What is happening during this time prior to the main form getting loaded?  Any information is greatly appreciated.  Thank you for your time and help.

Christopher
0
Comment
Question by:chmarch
3 Comments
 
LVL 33

Assisted Solution

by:it_saige
it_saige earned 250 total points
ID: 40573218
It really depends on your application and the framework used.  However in a nutshell. when your application is compiled, a PE executable is generated.  This PE application contains:
An entrypoint (usually Main).
A list of dependencies as dynamic libraries (which includes MSCOREE.DLL;  the .NET Common Object Runtime Execution Engine).
Additional metadata including the targeted .NET runtime version

When a user starts the application (by clicking on it, running it from a command line, etc.), the Windows loader implementation (in NTDLL.dll) takes over.  The loader code is responsible for putting the executable into memory, loading any dynamic link libraries, mapping any linked libraries into a place that the executable code can reach them and updating the Import Address Table.

Once this is all completed, the loader jumps to the defined entry point.  The entry point  goes to mscoreee.dll which was mapped into the processes memory.  MSCOREE.DLL looks at the metadata loaded from the PE executable (specifically the CLR header and targeted .NET runtime version).  From that it can bind the the correct CRL version using CorBindToRuntimeEx2.

CorBindToRuntimeEx2 loads the correct .NET runtime implementation (and returns a pointer to a COM interface allowing you to invoke that .NET runtime).  This code is loaded from the dlls in %WINDIR%\Microsoft.NET\Framework\{associated version number}

At this point, the MSCORREE shim uses the .NET ICLRRuntimeHost interface point to invoke the methods needed to initialize the .NET runtime, garbage collector, IL interpreter, JIT and IHostControl interfaces (that allow the .NET interpreter to talk back to the hosting process).  Finally, mscoree tells the IL interpreter to start executing your compiled application's IL code.Example of a comipled IL Manifest file (contains .NET runtime version, dependencies, resources and other metadata)Example IL Main entrypoint.The amazing thing is that all of the above, *usually*, happens in a matter of milliseconds.

The unfortunate thing, is that you cannot have a .NET Splash Screen for the above process as it is basically an unmanaged bootstrapper process and ultimately outside of the control of .NET.

-saige-
0
 
LVL 85

Accepted Solution

by:
Mike Tomlinson earned 250 total points
ID: 40573250
Do a search for "Cold versus Warm Start of .Net" to get an idea of what you're dealing with.  Basically it is .Net itself that is loading and then any specific assemblies needed for your app.

Process Explorer: https://technet.microsoft.com/en-us/sysinternals/bb896653.aspx
Improving Application Startup Time: https://msdn.microsoft.com/en-us/magazine/cc163655.aspx
Application Startup Time: https://msdn.microsoft.com/en-us/library/cc656914(v=vs.110).aspx
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Since .Net 2.0, Visual Basic has made it easy to create a splash screen and set it via the "Splash Screen" drop down in the Project Properties.  A splash screen set in this manner is automatically created, displayed and closed by the framework itsel…
It was really hard time for me to get the understanding of Delegates in C#. I went through many websites and articles but I found them very clumsy. After going through those sites, I noted down the points in a easy way so here I am sharing that unde…
Established in 1997, Technology Architects has become one of the most reputable technology solutions companies in the country. TA have been providing businesses with cost effective state-of-the-art solutions and unparalleled service that is designed…
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

830 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