.Net经典笔试题

时间:2022-09-05 22:51:52

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

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

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

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

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

2.C#中的委托是什么?事件是不是一种委托?

 答:委托可以把一个方法作为参数代入另一个方法。委托可以理解为指向函数的指针。事件不是委托,因为委托是类型,事件是对象。如果非要说事件和委托的关系,就是事件的内部是用委托实现的。

3.override与重载(overload)的区别

答:重载是方法的名称相同,参数或者参数类型不同,进行多次重载以适应不同的需要。重载是面向过程的;override是进行基类函数的重写,override是面向对象的。

4.dotnet中类(class)与结构(struct)的异同?

答:class可以被实例化,属于引用类型,是分配在内存的堆上的,class可以实现接口和单继承其他类,还可以作为基类型;struct属于值类型,是分配在内存的栈上的,不能作为基类型,但是可以实现接口。

5.CTSCLSCLR分别作何解释?

答:CTS:通用语言系统。CLS:通用语言规范。CLR:公共语言运行库。

6.什么是装箱和拆箱?

答:从值类型接口转换到引用类型装箱。从引用类型转换到值类型拆箱。

7.什么是受管制(托管)的代码?

答:托管代码是运行.NET 公共语言运行时CLR的代码;unsafe:非托管代码,不经过CLR运行。程序员自行分配和释放内存空间。

8.在C#中,string str = null  string str = “” 请尽量使用文字或图象说明其中的区别。

答:string str = null 是不给他分配内存空间,而string str = "" 给它分配长度为空字符串的内存空间。

9.写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。

答:解1:  select top 10 * from A where id not in (select top 30 id from A)

      解2:  select top 10 * from A where id > (select max(id) from (select top 30 id from A )as A)

10.请编程实现一个冒泡排序算法?

答:

      public static void BubbleSort(int[] array)
        {
            if (array == null || array.Length == 0) return;
            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;
                    }
                }
            }
        }

 

11. 一列数的规则如下: 1、1、2、3、5、8、13、21、34......  求第30位数是多少, 用递归算法实现。

答:    

      static void Main(string[] args)
        {
            Foo(30);
        }
public static int Foo(int i) { if (i <= 0) { return 0; } else if (i > 0 && i <= 2) { return 1; } else { return Foo(i - 1) + Foo(i - 2); } }

 

12.分析以下代码,完成填空

string strTmp = "abcdefg某某某";

int i= System.Text.Encoding.Default.GetBytes(strTmp).Length;

int j= strTmp.Length;

以上代码执行完后,i= j=

答:i=13,j=10

13.面向对象的语言具有________性、_________性、________

答:封装、继承、多态。

14.能用foreach遍历访问的对象需要实现 ________________接口或声明________________方法的类型。

答:IEnumerable 、 GetEnumerator。

15.产生一个int数组,长度为100,并向其中随机插入1-100,并且不能重复。

       static void Main(string[] args)
        {
            int[] array = GenerateNums(100);
        }
        public static int[] GenerateNums(int length)
        {
            int[] array = new int[length];

            ArrayList list = new ArrayList();
            Random random = new Random();
            while(list.Count < length)
            {
              int num = random.Next(1, length + 1);
                if(!list.Contains(num))
                {
                    list.Add(num);
                }
            }
            for (int i = 0; i < length; i++)
            {
                array[i] = (int)list[i];
            }
            return array;

        }

 16.假设数据库中有UserIncome两张表如下,请仔细分析下方的示例数据,然后写出SQL,得到右方的查询结果。

.Net经典笔试题

答:select Name,Year,Month,Income from(select UserId,Year,Month,Sum(Amount) Income from Income group by UserId,Year,Month)A join [User] on A.UserId = [User].Id

17.现有如下实体类:

    public class User
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
    public class Income
    {
        public int Id { get; set; }
        public int UserId { get; set; }
        public decimal Amount { get; set; }
        public int Year { get; set; }
        public int Month { get; set; }    
   }
   public class UserIncomeDto
    {
        public string Name { get; set; }
        public int Year { get; set; }
        public int Month { get; set; }
        public decimal Income { get; set; }
   }

    请用LINQ的方式得到上一题的查询结果。

public List<UserIncomeDto> GetUserIncomeDtos(List<User> users, List<Income> incomes)
        {
            var query1 = from income in incomes
                         group income by new { income.UserId, income.Year, income.Month } into g
                         select new { g.Key.UserId, g.Key.Year, g.Key.Month, Income = g.Sum(s => s.Amount) };
            var query2 = from income in query1
                         join user in users on income.UserId equals user.Id
                         select new UserIncomeDto() { Name = user.Name, Year = income.Year, Month = income.Month, Income = income.Income };

            return query2.ToList();
        }