.Net 面试题整理(一)

一、C# 的三大特性?算法

封装、继承、多态编程

二、简述 private、 protected、 public、 internal 修饰符的访问权限。数组

private : 私有成员, 在类的内部才能够访问。dom

protected : 保护成员,该类内部和继承类中能够访问。函数

public : 公共成员,彻底公开,没有访问限制。 性能

internal: 当前程序集内能够访问。spa

三、接口和类的区别code

接口:不能实例化,方法也没有具体的实现,被继承时,继承类必须实现接口的全部方法。对象

类:能够被实例化,被继承时,继承类也不须要从新实现被继承类中的方法。可是若是被继承类的方法中有abstract修饰的,继承类则须要实现这个方法。blog

四、在对象比较中,对象一致和对象相等分别是指什么?

对象一致指的是引用相同。对象相等指的是内容相等。

五、ref修饰参数和out修饰参数的区别

ref、out均可以从函数内部传出值,区别是,ref修饰的参数必须先初始化、而out不用

六、C#中String和string有什么区别?

  • string是C#中的类,String是Framework的类,
  • 若是写的是string,在编译的时候编译器会把他转换为String。因此直接使用String会让编译器少作工做,能够提升一下性能。
  • 在C#中建议使用string,比较符合规范 。
  • 在C#中string是关键字,而String不是。

七、 const和readonly二者区别? 

const:

  • 编译时常量
  • 自己就是静态变量
  • 只能定义基本类型,如int,string等等
  • 在声明的时候必须初始化,且不能修改

readonly:

  • 运行时常量
  • 不是静态变量,若是须要需加上“static”关键字
  • 能够定义一切类型
  • 能够延迟到构造函数初始化

八、public static const int A = 1; 这段代码有错误吗

错误:const 不能被修饰为 static
由于定义为常量(const)后就是静态的(static)

九、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,何时被执行,在return前仍是后?

会执行,在return前执行。

十、string str = null 与 string str = "" 的区别

string str = null 是不给他分配内存空间,而 string str = "" 给它分配长度为空字符串的内存空间。
string str = null 没有 string 对象,string str = "" 有一个字符串对象。

十一、什么叫作泛型?

泛型就是参数化类型

泛型的做用是减小重复代码

十二、什么是反射?

动态获取程序集信息、对象信息。

1三、装箱和拆箱

装箱是将值类型转化为引用类型的过程;

拆箱是将引用类型转化为值类型的过程

1四、2+5+”8” 获得的结果是什么

从左向右运算,int + string 是 string,因此是 “78”

扩展:”8”+2+5 是”825”,而 “8”+(2+5)是 “87”

1五、a=10,b=15,请在不使用第三方变量的状况下,把a、b的值互换

            int a = 10;
            int b = 15;
            a += b;
            b = a - b;
            a -= b;
            Console.WriteLine("a={0}\r\nb={1}", a, b);

1六、现有 1~10 共十个天然数,已随机放入一个有 8 个元素的数组 nums[8]

int[] numbers= { 3, 9, 8, 2, 4, 6, 10, 7 };

要求写出一个尽可能简单的方案,找出没有被放入数组的那 2 个数,并打印这 2 个数。

            int[] numbers = { 3, 9, 5, 2, 1, 6, 10, 7 };
            for (int i = 1; i <= 10; i++)
            {
                //经过使用默认的相等比较器肯定序列是否包含指定的元素。
                if (!numbers.Contains(i))
                {
                    Console.WriteLine(i);
                }
            }

1七、请编程实现一个冒泡排序算法?

            int[] array = { 1, 3, 5, 7, 13, 2, 4, 6, 8, 10 };
            for (int i = 0; i < array.Length; i++)
            {
                for (int j = 0; j < array.Length - 1 - i; j++)
                {
                    if (array[j] > array[j + 1])
                    {
                        int temp = array[j];
                        array[j] = array[j + 1];
                        array[j + 1] = temp;
                    }
                }
            }
            Console.WriteLine("冒泡排序");
            foreach (var t in array)
            {
                Console.WriteLine($"{t}");
            }

1八、产生一个int数组,长度为100,并向其中随机插入1-100,而且不能重复?

            var list = new List<int>();
            var random = new Random();
            while (true)
            {
                var temp2 = random.Next(1, 101);
                if (list.Count == 100)
                {
                    break;
                }
                if (!list.Contains(temp2))
                {
                    list.Add(temp2);
                }
            }
            foreach (var t in list)
            {
                Console.Write(t + ",");
            } 
相关文章
相关标签/搜索