I am curious about the string and primitive types. Article like this says string is primitive type. However second article on MSDN does not list string as primitive type.
In c# the types are primarily defined as two types: value types and primitive types.
First see the definition of primitive types in C#.
On the other hand, all primitive data types in C# are objects in the System namespace. For each data type, a short name, or alias, is provided. For instance, int is the short name for System.Int32 and double is the short form of System.Double.
Now, read this article for the difference: Primitive Types & Value Types
System.String
maps to "string
", which is a primitive type in the CLI. But in the reality, value types are the ones which go in the stack and not in the heap space.
So, the key is Value types vs Primitive types. By Microsoft's definition of primitive, it is a primitive type, but in a more general sense, its not.
There is no "Microsoft" definition of what a primitive type is.
There are only definitions of primitive types in a given context.
System.Boolean
System.Byte
System.SByte
System.Int16
System.UInt16
System.Int32
System.UInt32
System.Int64
System.UInt64
System.IntPtr
System.UIntPtr
System.Char
System.Double
System.Single
System
namespace), a way to define instances of that type with a literal; and permitting the use of these types as constants; the primitive types in VB.NET are:
System.Byte
System.SByte
System.UInt16
(UShort
)System.Int16
(Short
)System.UInt32
(UInteger
)System.Int32
(Integer
)System.UInt64
(ULong
)System.Int64
(Long
)System.Single
System.Double
System.Decimal
System.Boolean
System.DateTime
(Date
)System.Char
System.String
The C# specification (version 4) defines keyword aliases for some types, and also defines way of specifying literals for some values; it also defines, separately, which types are available in constant expressions; the closest concept to "primitive types" that C# has is in section 4.1.4: Simple types. (the word "primitive" is only used twice in the 600 pages document); these primitive types are simply defined as "value types that have a keyword alias in C#" - string
is not mentioned in that section:
System.SByte
(sbyte
)System.Byte
(byte
)System.Int16
(short
)System.UInt16
(ushort
)System.Int32
(int
)System.UInt32
(uint
)System.Int64
(long
)System.UInt64
(ulong
)System.Char
(char
)System.Single
(float
)System.Double
(double
)System.Boolean
(bool
)System.Decimal
(decimal
)You will see that there is only a partial overlap between all of these things; the CLR sees both pointer types as primitive, both VB.NET and C# see decimal as a primitive/simple type, only VB.NET sees DateTime as anything special, both VB.NET and C# have a keyword alias and a literal syntax for strings but only VB.NET specifies String
as being a "primitive type", while C# simply has a section of its specification dedicated to System.String
...
In conclusion: different contexts have different definitions for what a "primitive type" is. It does not matter - just learn how to use your programming language, there is no sense in fighting and thinking over such polymorphic words. Personally, I wonder why the property Type.IsPrimitive
even exists.
As for System.String
:
String
is its own very special snowflake;Both articles say that string is NOT a primitive type. Which it is not.
If you compile and run the example code from the second article it would print:
string is not a primitive type.
I think the confusion about this is, that the syntax of of creating a new string is similar to creating value types.
When defining a value type all of these are equal (on a 32 bit system anyway)
System.Int32 a = new System.Int32(5);
System.Int32 a = 5;
int a = 5;
Just like these when creating a reference type string:
System.String s = new System.String(new char[]{'h', 'e', 'l', 'l', 'o'});
System.String s = "hello";
string s = "hello";
Also we can compare strings by value even though they are reference types:
s == "hello";//true
This still does not make string a primitive type.
The accepted answer to this question should give you details on that.
No, the string is not a primitive type.
However, it has some characteristics common with the primitive types.
The language supports string literals in the code, so that you don't have to explicitly create String
instances using the new
keyword to get a string object.
There is also support for concatenating strings using the +
operator, which the compiler turns into a call to the String.Concat
method.
Strings are immutable, which means that it in most situations has value type semantics, just like the primitive types.
String is a reference type. To verify this do F12 on string.
enter image description here
Under Microsoft's definition of "primitive", string is not considered a primitive type. On the other hand, Microsoft tends to use terminology without really formulating a clear or consistent definition (e.g. "unmanaged resource"), and one could usefully define "primitive" to include "String", "Array", and "Object", since in their absence there would be no way to define types that could emulate them efficiently.