472,784 Members | 875 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 472,784 software developers and data experts.

Difference between Portable Executable (PE) file and a Assembly

Dear All,

What is difference between Portable Executable (PE) file and a Assembly?

Thanks,
Mahesh

Nov 19 '05 #1
8 6935
PE is the name given to standard 32 bit Windows executables and defined the
structure of the .exe file format. These files contain header information,
resource and the raw machine code compiled from an applications souirce
code.

An assembly on the other hand can be a dll or exe file compiled using a .NET
compiler and actually contain pseudo assembly code called IL, or
Intermediary Language. IL was devised by Microsoft to promote cross-platform
compatibility.

When an assembly is first executed, JIT compiling (Just-in-time) is invoked
and the assembly is then compiled using platofrm specific compilers to turn
the IL into native machine code specific to the platform on which it's
running. In principle, the same assembly can run on any platform that
supports the .NET Framework and has it's own JIT compiler.

That's my understanding of it.

Ben Fidge

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:03**********************************@microsof t.com...
Dear All,

What is difference between Portable Executable (PE) file and a Assembly?

Thanks,
Mahesh

Nov 19 '05 #2
Hi Mahesh:

PE is a file format.

An assembly is the smallest unit of deployment for .NET applications
and consist of one or more modules. These modules use the PE file
format.

--
Scott
http://www.OdeToCode.com/blogs/scott/

On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:
Dear All,

What is difference between Portable Executable (PE) file and a Assembly?

Thanks,
Mahesh


Nov 19 '05 #3

Thanks Ben, Thanks Scott.

But, following is definition of Ilasm.exe
--
When you compile managed code, the compiler converts the source code to MSIL
code. MSIL is a CPU-independent language and its code can be converted to
native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a portable
executable file from the MSIL code. *** You can then run the resulting
executable file to determine the performance of your application. This
enables you to generate the MSIL code and the metadata without emitting MSIL
in the portable executable file format. In addition, Ilasm.exe does not
create intermediate object files. It also does not have a linking stage to
generate a portable executable file.
--

***You can use the Ilasm tool, Ilasm.exe, to generate a portable executable
file from the MSIL code. ***

Considering this point, I think it generates a portable executable file (
??? different file ) from the MSIL code (Assembly ???)

Am I right? If right please I don’t understand what is PE and why it is used
then.

"Scott Allen" wrote:
Hi Mahesh:

PE is a file format.

An assembly is the smallest unit of deployment for .NET applications
and consist of one or more modules. These modules use the PE file
format.

--
Scott
http://www.OdeToCode.com/blogs/scott/

On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:
Dear All,

What is difference between Portable Executable (PE) file and a Assembly?

Thanks,
Mahesh


Nov 19 '05 #4
Yes you are right, a PE executable is created from the IL. PE is the file
format used to define 32bit Windows Executables. This is the native format
used by Windows. As mentioned, your .NET assembly is first compiled to IL
which is a platform independant assembly language. This is then compiled
into the platform specific binary, which for us Windows developers is called
PE.

PE has been around since the first versions of Windows NT and all versions
of Windows since Win95 have also been made to expect that particular format
to store binary executables. Obviously, as no current processors know how to
execute IL, it needs recompiling for the processor and platform it's running
on.

For more info on the format have a look here:

http://www.wotsit.org/search.asp?page=2&s=binary

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:47**********************************@microsof t.com...

Thanks Ben, Thanks Scott.

But, following is definition of Ilasm.exe
--
When you compile managed code, the compiler converts the source code to
MSIL
code. MSIL is a CPU-independent language and its code can be converted to
native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a
portable
executable file from the MSIL code. *** You can then run the resulting
executable file to determine the performance of your application. This
enables you to generate the MSIL code and the metadata without emitting
MSIL
in the portable executable file format. In addition, Ilasm.exe does not
create intermediate object files. It also does not have a linking stage to
generate a portable executable file.
--

***You can use the Ilasm tool, Ilasm.exe, to generate a portable
executable
file from the MSIL code. ***

Considering this point, I think it generates a portable executable file (
??? different file ) from the MSIL code (Assembly ???)

Am I right? If right please I don't understand what is PE and why it is
used
then.

"Scott Allen" wrote:
Hi Mahesh:

PE is a file format.

An assembly is the smallest unit of deployment for .NET applications
and consist of one or more modules. These modules use the PE file
format.

--
Scott
http://www.OdeToCode.com/blogs/scott/

On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:
>Dear All,
>
>What is difference between Portable Executable (PE) file and a Assembly?
>
>Thanks,
>Mahesh
>
>


Nov 19 '05 #5

Thanks Ben. This is clear to me now.

I would be grateful if you answer to this question also.

I assume that JIT compiler and Ilasm.exe convert the IL code into machine
dependent code.

I knew that there are 2 tools ie JIT and one more tool [I forgot name] which
do the above. Then in .NET who uses the Ilasm.exe tool.

"Ben Fidge" wrote:
Yes you are right, a PE executable is created from the IL. PE is the file
format used to define 32bit Windows Executables. This is the native format
used by Windows. As mentioned, your .NET assembly is first compiled to IL
which is a platform independant assembly language. This is then compiled
into the platform specific binary, which for us Windows developers is called
PE.

PE has been around since the first versions of Windows NT and all versions
of Windows since Win95 have also been made to expect that particular format
to store binary executables. Obviously, as no current processors know how to
execute IL, it needs recompiling for the processor and platform it's running
on.

For more info on the format have a look here:

http://www.wotsit.org/search.asp?page=2&s=binary

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:47**********************************@microsof t.com...

Thanks Ben, Thanks Scott.

But, following is definition of Ilasm.exe
--
When you compile managed code, the compiler converts the source code to
MSIL
code. MSIL is a CPU-independent language and its code can be converted to
native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a
portable
executable file from the MSIL code. *** You can then run the resulting
executable file to determine the performance of your application. This
enables you to generate the MSIL code and the metadata without emitting
MSIL
in the portable executable file format. In addition, Ilasm.exe does not
create intermediate object files. It also does not have a linking stage to
generate a portable executable file.
--

***You can use the Ilasm tool, Ilasm.exe, to generate a portable
executable
file from the MSIL code. ***

Considering this point, I think it generates a portable executable file (
??? different file ) from the MSIL code (Assembly ???)

Am I right? If right please I don't understand what is PE and why it is
used
then.

"Scott Allen" wrote:
Hi Mahesh:

PE is a file format.

An assembly is the smallest unit of deployment for .NET applications
and consist of one or more modules. These modules use the PE file
format.

--
Scott
http://www.OdeToCode.com/blogs/scott/

On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:

>Dear All,
>
>What is difference between Portable Executable (PE) file and a Assembly?
>
>Thanks,
>Mahesh
>
>


Nov 19 '05 #6
I've never used the ILASM tool day-to-day, only for experimentation.

Referring back to the MS documentation, ILASM is a tool for vendors creating
IL generators. It allows them to concentrate on the actual renderring of IL
from their custom language compilers without the need to write an IL to
machine-code compiler.

I may be wrong but JIT may also use ILASM when compiling IL to native
machine code for the first time, but you may want to check up on this. I
certainly don't consider myself an expert on all thing IL!!

http://msdn.microsoft.com/library/de...erIlasmexe.asp
Ben
"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:15**********************************@microsof t.com...

Thanks Ben. This is clear to me now.

I would be grateful if you answer to this question also.

I assume that JIT compiler and Ilasm.exe convert the IL code into machine
dependent code.

I knew that there are 2 tools ie JIT and one more tool [I forgot name]
which
do the above. Then in .NET who uses the Ilasm.exe tool.

"Ben Fidge" wrote:
Yes you are right, a PE executable is created from the IL. PE is the file
format used to define 32bit Windows Executables. This is the native
format
used by Windows. As mentioned, your .NET assembly is first compiled to IL
which is a platform independant assembly language. This is then compiled
into the platform specific binary, which for us Windows developers is
called
PE.

PE has been around since the first versions of Windows NT and all
versions
of Windows since Win95 have also been made to expect that particular
format
to store binary executables. Obviously, as no current processors know how
to
execute IL, it needs recompiling for the processor and platform it's
running
on.

For more info on the format have a look here:

http://www.wotsit.org/search.asp?page=2&s=binary

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:47**********************************@microsof t.com...
>
> Thanks Ben, Thanks Scott.
>
> But, following is definition of Ilasm.exe
> --
> When you compile managed code, the compiler converts the source code to
> MSIL
> code. MSIL is a CPU-independent language and its code can be converted
> to
> native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a
> portable
> executable file from the MSIL code. *** You can then run the resulting
> executable file to determine the performance of your application. This
> enables you to generate the MSIL code and the metadata without emitting
> MSIL
> in the portable executable file format. In addition, Ilasm.exe does not
> create intermediate object files. It also does not have a linking stage
> to
> generate a portable executable file.
> --
>
> ***You can use the Ilasm tool, Ilasm.exe, to generate a portable
> executable
> file from the MSIL code. ***
>
> Considering this point, I think it generates a portable executable file
> (
> ??? different file ) from the MSIL code (Assembly ???)
>
> Am I right? If right please I don't understand what is PE and why it is
> used
> then.
>
>
>
> "Scott Allen" wrote:
>
>> Hi Mahesh:
>>
>> PE is a file format.
>>
>> An assembly is the smallest unit of deployment for .NET applications
>> and consist of one or more modules. These modules use the PE file
>> format.
>>
>> --
>> Scott
>> http://www.OdeToCode.com/blogs/scott/
>>
>> On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
>> <su*****@discussions.microsoft.com> wrote:
>>
>> >Dear All,
>> >
>> >What is difference between Portable Executable (PE) file and a
>> >Assembly?
>> >
>> >Thanks,
>> >Mahesh
>> >
>> >
>>
>>
>


Nov 19 '05 #7
ILASM is more of a repackaging tool. It takes IL code and packages the
code into a file in the PE format. If you wrote your own compiler that
generated MSIL, then you could use ILASM to put the MSIL into a
managed executable. ILASM doesn't generate native code.

NGEN.EXE can be used to generate native code for an assembly. I'd only
recommend using NGEN if you have a good reason to avoid JIT compiling.

--
Scott
http://www.OdeToCode.com/blogs/scott/
On Sun, 1 May 2005 15:11:14 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:

Thanks Ben. This is clear to me now.

I would be grateful if you answer to this question also.

I assume that JIT compiler and Ilasm.exe convert the IL code into machine
dependent code.

I knew that there are 2 tools ie JIT and one more tool [I forgot name] which
do the above. Then in .NET who uses the Ilasm.exe tool.

"Ben Fidge" wrote:
Yes you are right, a PE executable is created from the IL. PE is the file
format used to define 32bit Windows Executables. This is the native format
used by Windows. As mentioned, your .NET assembly is first compiled to IL
which is a platform independant assembly language. This is then compiled
into the platform specific binary, which for us Windows developers is called
PE.

PE has been around since the first versions of Windows NT and all versions
of Windows since Win95 have also been made to expect that particular format
to store binary executables. Obviously, as no current processors know how to
execute IL, it needs recompiling for the processor and platform it's running
on.

For more info on the format have a look here:

http://www.wotsit.org/search.asp?page=2&s=binary

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:47**********************************@microsof t.com...
>
> Thanks Ben, Thanks Scott.
>
> But, following is definition of Ilasm.exe
> --
> When you compile managed code, the compiler converts the source code to
> MSIL
> code. MSIL is a CPU-independent language and its code can be converted to
> native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a
> portable
> executable file from the MSIL code. *** You can then run the resulting
> executable file to determine the performance of your application. This
> enables you to generate the MSIL code and the metadata without emitting
> MSIL
> in the portable executable file format. In addition, Ilasm.exe does not
> create intermediate object files. It also does not have a linking stage to
> generate a portable executable file.
> --
>
> ***You can use the Ilasm tool, Ilasm.exe, to generate a portable
> executable
> file from the MSIL code. ***
>
> Considering this point, I think it generates a portable executable file (
> ??? different file ) from the MSIL code (Assembly ???)
>
> Am I right? If right please I don't understand what is PE and why it is
> used
> then.
>
>
>
> "Scott Allen" wrote:
>
>> Hi Mahesh:
>>
>> PE is a file format.
>>
>> An assembly is the smallest unit of deployment for .NET applications
>> and consist of one or more modules. These modules use the PE file
>> format.
>>
>> --
>> Scott
>> http://www.OdeToCode.com/blogs/scott/
>>
>> On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
>> <su*****@discussions.microsoft.com> wrote:
>>
>> >Dear All,
>> >
>> >What is difference between Portable Executable (PE) file and a Assembly?
>> >
>> >Thanks,
>> >Mahesh
>> >
>> >
>>
>>
>



Nov 19 '05 #8
Thanks Scott, thanks Ben.

"Scott Allen" wrote:
ILASM is more of a repackaging tool. It takes IL code and packages the
code into a file in the PE format. If you wrote your own compiler that
generated MSIL, then you could use ILASM to put the MSIL into a
managed executable. ILASM doesn't generate native code.

NGEN.EXE can be used to generate native code for an assembly. I'd only
recommend using NGEN if you have a good reason to avoid JIT compiling.

--
Scott
http://www.OdeToCode.com/blogs/scott/
On Sun, 1 May 2005 15:11:14 -0700, suresh_C#
<su*****@discussions.microsoft.com> wrote:

Thanks Ben. This is clear to me now.

I would be grateful if you answer to this question also.

I assume that JIT compiler and Ilasm.exe convert the IL code into machine
dependent code.

I knew that there are 2 tools ie JIT and one more tool [I forgot name] which
do the above. Then in .NET who uses the Ilasm.exe tool.

"Ben Fidge" wrote:
Yes you are right, a PE executable is created from the IL. PE is the file
format used to define 32bit Windows Executables. This is the native format
used by Windows. As mentioned, your .NET assembly is first compiled to IL
which is a platform independant assembly language. This is then compiled
into the platform specific binary, which for us Windows developers is called
PE.

PE has been around since the first versions of Windows NT and all versions
of Windows since Win95 have also been made to expect that particular format
to store binary executables. Obviously, as no current processors know how to
execute IL, it needs recompiling for the processor and platform it's running
on.

For more info on the format have a look here:

http://www.wotsit.org/search.asp?page=2&s=binary

"suresh_C#" <su*****@discussions.microsoft.com> wrote in message
news:47**********************************@microsof t.com...
>
> Thanks Ben, Thanks Scott.
>
> But, following is definition of Ilasm.exe
> --
> When you compile managed code, the compiler converts the source code to
> MSIL
> code. MSIL is a CPU-independent language and its code can be converted to
> native code. ***You can use the Ilasm tool, Ilasm.exe, to generate a
> portable
> executable file from the MSIL code. *** You can then run the resulting
> executable file to determine the performance of your application. This
> enables you to generate the MSIL code and the metadata without emitting
> MSIL
> in the portable executable file format. In addition, Ilasm.exe does not
> create intermediate object files. It also does not have a linking stage to
> generate a portable executable file.
> --
>
> ***You can use the Ilasm tool, Ilasm.exe, to generate a portable
> executable
> file from the MSIL code. ***
>
> Considering this point, I think it generates a portable executable file (
> ??? different file ) from the MSIL code (Assembly ???)
>
> Am I right? If right please I don't understand what is PE and why it is
> used
> then.
>
>
>
> "Scott Allen" wrote:
>
>> Hi Mahesh:
>>
>> PE is a file format.
>>
>> An assembly is the smallest unit of deployment for .NET applications
>> and consist of one or more modules. These modules use the PE file
>> format.
>>
>> --
>> Scott
>> http://www.OdeToCode.com/blogs/scott/
>>
>> On Sun, 1 May 2005 12:17:05 -0700, suresh_C#
>> <su*****@discussions.microsoft.com> wrote:
>>
>> >Dear All,
>> >
>> >What is difference between Portable Executable (PE) file and a Assembly?
>> >
>> >Thanks,
>> >Mahesh
>> >
>> >
>>
>>
>


Nov 19 '05 #9

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

6
by: Jane Doe | last post by:
Hi, I'd like to write a PHP script that opens a Windows binary file (EXE, DLL, OCX, etc.), and extracts its version number, if any. Does anyone know if a module is available to do this? Thank...
9
by: Eric | last post by:
Problem: -------- I'm trying to create an executable jar file. I can do so as long as I don't use the "package" statement in my source code. Once I put the package statement in I can't execute...
4
by: Frank Jona | last post by:
Intellisense with C# and a multi-file assembly is not working. With VB.NET it is working. Is there a fix availible? We're using VisualStudio 2003 Regards Frank
11
by: zealot | last post by:
What is the relation/difference between a header file, dll and library?
2
by: keith | last post by:
In my app, an executable (app.exe) calls functions from an assembly dll (subapp.dll). app.exe has config file: app.exe.config <?xml version="1.0" encoding="utf-8" ?> <configuration>...
2
by: Bernd | last post by:
I'm stumped. I would like to create a single file executable for a vb project that also calls a c# project
2
by: pooja | last post by:
what is an assembly and how does it related with portable executable in ..net architecture?
0
by: Renil | last post by:
Hi, I am getting an error "Cannot take the address of, get the size of, or declare a pointer to a managed type" while working with PE file reading.. I'm adding the code below byte Data = new...
4
by: =?Utf-8?B?aWduaGVucnk=?= | last post by:
I have mixed-mode multi-file assembly of several netmodules and a dll. All are generated using c# compiler, vc++ compiler and vc++ linker from command prompt. I can browse the content of the...
0
by: Rina0 | last post by:
Cybersecurity engineering is a specialized field that focuses on the design, development, and implementation of systems, processes, and technologies that protect against cyber threats and...
0
by: erikbower65 | last post by:
Here's a concise step-by-step guide for manually installing IntelliJ IDEA: 1. Download: Visit the official JetBrains website and download the IntelliJ IDEA Community or Ultimate edition based on...
0
by: kcodez | last post by:
As a H5 game development enthusiast, I recently wrote a very interesting little game - Toy Claw ((http://claw.kjeek.com/))。Here I will summarize and share the development experience here, and hope it...
0
by: Taofi | last post by:
I try to insert a new record but the error message says the number of query names and destination fields are not the same This are my field names ID, Budgeted, Actual, Status and Differences ...
14
DJRhino1175
by: DJRhino1175 | last post by:
When I run this code I get an error, its Run-time error# 424 Object required...This is my first attempt at doing something like this. I test the entire code and it worked until I added this - If...
5
by: DJRhino | last post by:
Private Sub CboDrawingID_BeforeUpdate(Cancel As Integer) If = 310029923 Or 310030138 Or 310030152 Or 310030346 Or 310030348 Or _ 310030356 Or 310030359 Or 310030362 Or...
0
by: lllomh | last post by:
Define the method first this.state = { buttonBackgroundColor: 'green', isBlinking: false, // A new status is added to identify whether the button is blinking or not } autoStart=()=>{
0
by: lllomh | last post by:
How does React native implement an English player?
2
by: DJRhino | last post by:
Was curious if anyone else was having this same issue or not.... I was just Up/Down graded to windows 11 and now my access combo boxes are not acting right. With win 10 I could start typing...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.