.Net 面试题整理(一)

1、C# 的三大特性?

封装、继承、多态

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

private : 私有成员, 在类的内部才可以访问。

protected : 保护成员,该类内部和继承类中可以访问。

public : 公共成员,完全公开,没有访问限制。

internal: 当前程序集内可以访问。

3、接口和类的区别

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

类:可以被实例化,被继承时,继承类也不需要重新实现被继承类中的方法。但是如果被继承类的方法中有abstract修饰的,继承类则需要实现这个方法。

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

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

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

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

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

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

7、 const和readonly两者区别?

const:

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

readonly:

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

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

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

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

会执行,在return前执行。

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

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

11、什么叫做泛型?

泛型就是参数化类型

泛型的作用是减少重复代码

12、什么是反射?

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

13、装箱和拆箱

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

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

14、2+5+”8” 得到的结果是什么

从左向右运算,int + string 是 string,所以是 “78”

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

15、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);

16、现有 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);
                }
            }

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

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}");
            }

18、产生一个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 + ",");
            }
(0)

相关推荐