一些Asp.Net面试题答案

工作时间长了总是用同样的一些东西  其他的有些生疏  闲来看看面试题练习一下:  题目出处嘛...aspnet-tests-for-juniors

转载请注明来源:http://www.cnblogs.com/zaiyuzhong/p/answer-for-aspnet-test.html

1. 定义接口IQuestion:

interface IQuestion

{

  string Title{get;set;}

  QuestionType Type{get;}

  string GetAnswer();

}

小结: interface默认为internal, 可加上public, 只有这两种访问修饰符; 成员不能声明访问修饰符 全是public; 只包含方法、属性、事件或索引器的签名(其实全是方法);

2. 定义抽象类QuestionBase:

internal abstract class QuestionBase:IQuestion

{

  public string Title{get;set;}

  public abstract QuestionType Type{get;}

  public virtual string GetAnswer()

  {

    return "默认答案";

  }

}

小结: 有默认实现的方法是虚方法, 通过 virtual 声明, 子类可重写可不重写;

3. 定义TextQuestion,MultipleChoiceQuestion类:

internal class TextQuestion:QuestionBase

{

  public override QuestionType Type{get{return QuestionType.Text}}

  public override GetAnswer()

  {

    return "文本答案";

  }

}

MultipleChoiceQuestion 只有值不一样, 略

小结: 题目没提示, 很可能忘记override Type属性;

4. 完成扩展方法 WhereNotDeleted:

public static class Tools

{

  public static IEnumerable<Product> WhereNotDeleted(this IEnumerable<Product> sender)

  {

    return sender.Where(it => it.IsDeleted == "false");

  }

}

小结: 扩展方法是静态类的静态方法, 第一个参数this修饰;
    我有一些疑问: 1, Product的IsDeleted用bool类型比string要好;
    2, 不清楚这道题要考声明扩展方法还是筛选WhereNotDeleted, 如果是后者, 像我这样的答案应该是不行的;

5. 写出Sql语句: (SQL语句关键字全大写是个人习惯)

SELECT [Name],[Year],[Month],SUM([Amount]) AS Income
FROM [User] INNER JOIN [Income] ON [User].Id=[Income].UserId
GROUP BY [Name],[Year],[Mouth]

小结: 应该是考联合查询和GROUP BY, 测了一下四种联合查询都可以(主外键的值都对应的上,可能提问会问到区别), 测试环境SQL Server 2014;

  这里有个坑 User(表名和内置函数User()冲突, 加[]表示xx), 开始写了一个简单的select怎么都报错, 以为自己多年不用SQL忘光了, 大囧;

6. Linq语句得到5结果:

var r = from u in users
    join i in incomes on u.Id equals i.UserId
    group i by new {u.Name, i.Year, i.Mouth} into temp
    select new UserIncomeDto() {
      Name = temp.Key.Name,
      Year = temp.Key.Year,
      Month = temp.Key.Month,
      Income = temp.Sum(it => it.Amount)
    };
return r.ToList();

小结: 熟悉Linq...

7. 修改HTML和路由:

HTML:  <form action="..." method="post">

    <input name="username" type="text" placeholder="username" />

    <input name="password" type="password" placeholder="password" />

Routes: routes.MapRoute(

      name: "MobileLogin"

      url: "/admin/mobile/user/login",

      defaults: new { controller = "User", action = "Login"}

      ); //注意路由顺序

小结: form 可能会忘记声明method, 我不记得form默认是post还是get了, 还是声明一下的好;

8. 完成Require方法:

private void Require(Func<User,string> selector, string msg)

{

  var value = selector.Invoke(this);

  if(string.IsNullOrEmpty(value)) throw new Exception(msg);

}

小结: 这题好, 以前没注意过还可以这么造...

时间: 2024-08-07 11:13:09

一些Asp.Net面试题答案的相关文章

ASP.NET面试题130道

 130道ASP.NET面试题 1. 简述 private. protected. public. internal 修饰符的访问权限. 答 . private : 私有成员, 在类的内部才可以访问. protected : 保护成员,该类内部和继承类中可以访问. public : 公共成员,完全公开,没有访问限制. internal: 在同一命名空间内可以访问. 2 .列举ASP.NET 页面之间传递值的几种方式. 答. 1.使用QueryString, 如....?id=1; respons

远光软件ASP.NET笔试题小汇总

ASP.NET笔试题是ASP.NET程序员面试必须经历的,一般会叫你填两个表 1个是你的详细信息表 1个是面试题答卷 两个都要注意反正面是否都有内容不要遗漏,如果考你机试一般也有两种,就是程序连接数据库或一些基本的算法(二分查找,递归等),公司一般都是测试你的基本功是否扎实,如果你基本功好就游刃有余不必紧张! 那么下面就是一些ASP.NET笔试题,希望对你的面试准备有帮助. 1.new有几种用法 第一种:new Class(); 第二种:覆盖方法 public new XXXX(){} 第三种:

(转)130道ASP.NET面试题

130道ASP.NET面试题 转自http://blog.csdn.net/kingmax54212008/article/details/2021204 1. 简述 private. protected. public. internal 修饰符的访问权限.答 . private : 私有成员, 在类的内部才可以访问. protected : 保护成员,该类内部和继承类中可以访问. public : 公共成员,完全公开,没有访问限制. internal: 在同一命名空间内可以访问. 2 .列举

关于完整解答Leo C.W博客中名为“我们公司的ASP.NET 笔试题,你觉得难度如何”的所有题目

关于完整解答Leo C.W博客中名为“我们公司的ASP.NET 笔试题,你觉得难度如何”的所有题目,请大家鉴定,不足之处,敬请指教! 第1到3题解答如下: public enum QuestionType { Text = 0, MultipleChoice = 1 } public interface IQuestion { string Title { get; set; } QuestionType Category { get; } } public abstract class Que

攻克要塞独家发布2017年上半年软考网络工程师考试下午试题答案

2017年上半年软考网络工程师考试已经于昨天下午举行,各位参考考试的小伙伴们,考完之后最关心的就是成绩了,为此,攻克要塞团队在尽快的时间内,为大家准备了,下午试题答案. 今年的下午题考了比较多的华为配置,但是基本上可以从上下文来答题,难度不大. 参考答案请从附件下载!

JQuery面试题答案

jQuery面试题答案 转自:http://blog.csdn.net/zhangpei_xf/article/details/8822021 一.Jquery测试题 下面哪种不是jquery的选择器?(单选)A.基本选择器 B.后代选择器 C.类选择器 D.进一步选择器考点:jquery的选择器 (C) 当DOM加载完成后要执行的函数,下面哪个是正确的?(单选)jQuery(expression, [context]) B.jQuery(html, [ownerDocument]) C.jQu

经典ASP.NET 面试题

经典ASP.NET 面试题 一.理论知识题目 1.简述private , protected, public, internal 修饰符的访问权限.***** 答:private:私有成员,在类的内部才可以访问. protected:保护成员,在该类的内部可以访问和继承类中可以访问. public:公共成员,完成公开,没有访问限制. internal:在同一命名空间内可以访问.   2.override 与重载(overload)的区别.***** 答:override 是指父类和子类之间方法的

Linux相关面试题&amp;答案

Linux相关面试题&答案 Linux面试题&答案 假设apache日志格式为:118.78.199.98 – - [09/Jan/2010:00:59:59 +0800] "GET /Public/Css/index.css HTTP/1.1″ 304 – "http://www.a.cn/common/index.php" "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; GTB6.

【每日3分钟技术干货 | 面试题+答案 | Redis篇(一)】

1. Redis 是什么?**都有哪些使用场景?** 我们先来理解经典的CAP理论: 一致性:是指从数据层面来看的一致性. 可用性:是指从系统层面的可用性. 容错性:是指从网络层面的的容错性. 数据库逐渐从关系数据库向不同领域不同层次分化.随着读多写少场景的出现,导致需要读取数据的时间变慢,为了提升性能,出现了数据库缓存技术,对数据库的读取进行分离.web2.0时代,网民的生产力大增,存储总量也在增加,目前还是读多写少模式,原有的缓存技术显然不能满足写的压力,所以,出现了分库分表,实现读写分离.