About intrinsic members

Short description

Provides information about PowerShell's intrinsic members that are available to all PowerShell objects.

Detailed description

When objects are created, PowerShell adds some "hidden" properties and methods to each object. These properties and methods are known as intrinsic members. These intrinsic members are normally hidden from view. Some of these members can be seen using the Get-Member -Force command.

Object views

The intrinsic members include a set of MemberSet properties that represent a view of the object. You can find the MemberSet properties using the Get-Member -Force command on any PowerShell object. Every PowerShell object includes the following MemberSet properties.


This psbase contains the members the base object without extension or adaptation.


The psadapted view shows the base object plus the adapted members, if present. Adapted members are added by the Extended Type System (ETS).


The psextended view only shows the members added by the Types.ps1xml files and the Add-Member cmdlet. Any object can be extended at runtime using the Add-Member cmdlet.


The base type of all PowerShell objects is [PSObject]. However, when an object gets created, PowerShell also wraps the object with a [PSObject] instance. The psobject member allows access to the [PSObject] wrapper instance. The wrapper includes methods, properties, and other information about the object. Using the psobject member is comparable to using Get-Member, but there are some differences since it is only accessing the wrapper instance.

Type information


PSTypeNames is a CodeProperty member that lists the object type hierarchy in order of inheritance. For example:

$file = Get-Item C:\temp\test.txt

As shown above, it starts with the most specific object type, System.IO.FileInfo, and continues down to the most generic type, System.Object.


PowerShell adds two hidden methods to all PowerShell objects. These methods are not visible using the Get-Member -Force command or tab completion.

ForEach() and Where()

The ForEach() and Where() methods are available to all PowerShell objects. However, they are most useful when working with collections. For more information on how to use these methods, see about_Arrays.


Count and Length

The Count and Length properties are available to all PowerShell objects. These are similar to each other but may work differently depending on the data type. For more information about these properties, see about_Properties.

Array indexing scalar types

When an object is not an indexed collection, using the index operator to access the first element returns the object itself. Index values beyond the first element return $null.

PS> (2)[0]
PS> (2)[-1]
PS> (2)[1] -eq $null
PS> (2)[0,0] -eq $null

For more information, see about_Operators.

New() method for types

Beginning in PowerShell 5.0, PowerShell adds a static New() method for all .NET types. The following examples produce the same result.

$expression = New-Object -TypeName regex -ArgumentList 'pattern'
$expression = [regex]::new('pattern')

Using the new() method performs better than using New-Object.

For more information, see about_Classes.