What is type-safe in .net?

C#.Net

C# Problem Overview


What is type-safe?

What does it mean and why is it important?

C# Solutions


Solution 1 - C#

If you're asking what the idea of "type-safe" in general means, it's the characteristic of code that allows the developer to be certain that a value or object will exhibit certain properties (i.e., be of a certain type) so that he/she can use it in a specific way without fear of unexpected or undefined behavior.

For instance, in C#, you could say the ArrayList class is not type-safe because it can store any object, which means you can do something like the following:

var integers = new ArrayList();
integers.Add(1);
integers.Add(2);
integers.Add("3");

for (int i = 0; i < integers.Count; ++i) {
    int integer = (int)integers[i];
    // do something
}

The above will compile because the value "3", even though it's a string and not an integer, can legally be added to an ArrayList since String derives (like Int32) from Object. However, it will throw an InvalidCastException when you try to set integer to (int)integers[2] because a String cannot be cast to an Int32.

On the other hand, the List<T> class is type-safe for exactly the opposite reason--i.e., the above code would not compile if integers were a List<int>. Any value that you the developer access from within a type-safe List<int> you can be certain is an int (or whatever the corresponding T is for any generic List<T>); and you can therefore be sure that you'll be able to perform operations such as casting to int (obviously) or, say, long.

Solution 2 - C#

C - You declare an int, cast it to char and access memory beyond int's boundary

int i = 10;
char *s = (char*)i;
print(*(s+10));

C# - Types are safe

int i = 10;
char *s //This is invalid unless you are using unsafe context. 

Pointers are not directly supported by .NET

Solution 3 - C#

> Type-safe code accesses only the > memory locations it is authorized to > access. For example, type-safe code > cannot read values from another > object's private fields. It accesses > types only in well-defined, allowable > ways. > > During just-in-time (JIT) compilation, > an optional verification process > examines the metadata and Microsoft > intermediate language (MSIL) of a > method to be JIT-compiled into native > machine code to verify that they are > type safe. This process is skipped if > the code has permission to bypass > verification > > Although verification of type safety > is not mandatory to run managed code, > type safety plays a crucial role in > assembly isolation and security > enforcement. When code is type safe, > the common language runtime can > completely isolate assemblies from > each other. This isolation helps > ensure that assemblies cannot > adversely affect each other and it > increases application reliability.

For more refer msdn link

A good article explaining it is here

Solution 4 - C#

Did you mean type-safe in particular or type-safety in general?

I disagree with the accepted answer: ArrayList is type-safe ignorant (neither type-safe nor not type-safe): https://stackoverflow.com/a/17984521/1145224

Richter - CLR via C#, 4th edition (page 93):

> Type-safety is the main feature of CLR. You can always discover > object's exact type by calling nonvirtual GetType method of the > System.Object. > > For example Hero class can not override GetType method to become a type of SuperHero.

This System.Object feature enables CLR to check the possibility of casting objects at runtime. For example:

internal class Employee { ... }
 
public sealed class Program 
{

    public static Main() 
    {
        DateTime dt = new DateTime(2016, 1, 1);
        PromoteEmployee(newYears);
    }

    public static PromoteEmployee(Object o)
    {
        Employee e = (Employee)o; //InvalidCastException, runtime error
    }
}

Casting DateTime type to Employee type is an example of a not type-safe attempt to cast.

Solution 5 - C#

I don't agree with some answers here. C# has few levels of safety.

EDIT: Type safety has 2 levels of meaning (if we generally discus about programming languages, as in this thread)

One is compile time type-safety, near to refactoring etc, compiler catch typos, misspelled assigning of values to wrong variables (properties), i.e. string to int variable. Typical C# code is type-safe, known way to disable this feature is dynamic keyword, or non generic containers, errors like above are delayed to runtime. Example: non-hacking C/C++ code is (generally) type safe at compile time. I think is possible write (hacking) casting in C# which hide type conflicts.

Next level is runtime type-safety, C# is safe in general (without unsafe sections). Even dynamic value are checked on runtime. In contrast: C/C++ isn't type safe at runtime. If compiler accept code, un-logical assigning isn't checked at runtime, providing bizarre / strange / system level or late errors, typical for C language.

Few of answerers in this thread mix other areas where C# is safe (memory safety, range safety, null pointer etc). To be strict, these are different kind of safety.

Theory: https://en.wikipedia.org/wiki/Type_safety

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionSurya sasidharView Question on Stackoverflow
Solution 1 - C#Dan TaoView Answer on Stackoverflow
Solution 2 - C#A9S6View Answer on Stackoverflow
Solution 3 - C#HotTesterView Answer on Stackoverflow
Solution 4 - C#Anton LyhinView Answer on Stackoverflow
Solution 5 - C#Jacek CzView Answer on Stackoverflow