开发者社区> 尚武科技> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

CSDN社区分享面试经历活动作品13——ASP.NET面试经历分享(最终版)

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/CSDN/article/details/7301995 200X年12月23日的一次面试经历(共六轮),至此9-X周年之际,和各位朋友分享,希望对各位朋友有用,有些自己的答案贴出来也仅仅是抛砖引玉,希望各位朋友不吝赐教,说句老实话,面试的时候时间很紧,很难考虑最优算法。
+关注继续查看
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/CSDN/article/details/7301995
200X年12月23日的一次面试经历(共六轮),至此9-X周年之际,和各位朋友分享,希望对各位朋友有用,有些自己的答案贴出来也仅仅是抛砖引玉,希望各位朋友不吝赐教,说句老实话,面试的时候时间很紧,很难考虑最优算法

起因是朋友推荐我去W公司应聘Senior SDE这个职位,应该算是内部推荐了,下面是招聘要求

Title: Senior SDE (高级软件开发工程师)
1. 本科学历,计算机相关专业
2. 英语CET4,能熟练阅读英文文档
3. 工作经验4年以上
4. 优秀的逻辑分析能力,良好的沟通能力
5. 丰富的ASP.NET 、C#、 SQL Server的经验
6. 有丰富的项目开发、测试经验
7. 独立带领小组完成项目的能力

应该还算吻合,自己很久没有被面试了,也想去找找面试的感觉,而且对方也是个大公司,也比较期待。

下了地铁,由于地方不熟,打车又打不上,居然晚了了15分钟才找到公司(后来发现是通知我面试的MM没说清楚,但自己没有问清楚是最不应该的),先去找WC解决一下,然后准备面试。

进门和前台MM说明了一下迟到的理由,带我到会议室,给了一套笔试题目,一共七道,没有说明多久需要做完

第一轮笔试

算法题:可以使用c,c#和java

1. 已知m和n是已经排序好的数组,从小到大,现在要合并这两个数组内的数到一个数组,仍然要求是从小到大排序

2. 使用递归求n的阶乘

3. 有1,2,2,3,4,5六个数,要求输出他们组合的全排列,4不能在第三位,5和3不能相邻

4. 请解释HTTP,Cookie和Session

5. 请解释视图,存储过程,左连接

6. 请简单描述三层架构

7. 写一段HTML页面完成注册功能

看了题目,没有给答题纸,只能在背面写了,

先从第四题开始写起,写HTTP协议的时候心里有点嘀咕,他不会等会真问我HTTP协议的细节吧。Cookie和Session先讲了最重要的,都是Web应用程序中保存特定用户信息的。Cookie信息存放在客户端(大小限制4K,只能存放string类型,不安全,但可以考虑使用加密和验证),Session信息在服务器端(安全性好,占服务器资源,除InProc方式存放的对象需要可序列化),然后简单说明临时Cookie和永久Cookie,Session的三种存放方式(InProc、StateServer、SQLServer)

第五题,分别说明视图和存储过程的概念/优点/可能使用它们的主要场景

第六题,简单地描述三层架构,从代码重用/团队协作/系统维护/测试等上面说了下,网上相信能找到很多更好的答案。

第七题,写标记的时候尽量按照xhtml的规范来写,表单的提交,简单的样式和javascript验证的代码

这时有人进来,我赶紧又要了一张纸(后面的算法题肯定需要),这4个题目的答案大概写了A4纸的1面。

回过来写了算法中最简单的第二题:


public static int Func(int n)
{
    if (n < 0)
    {
        throw new ArgumentException("不能小于0");        
    }

    if (n == 0 || n == 1)
    {
        return 1;
    }

    return n * Func(n - 1);
}

看了一下第一题和第三题,还是感觉第一题更简单,尽量考虑了算法的复杂度,但这个不是本人的强项,不过常识是算法题只应该用一个循环,当时大致写的代码如下:


public static int[] Func(int[] SLm, int[] SLn)
{
    if (SLm == null || SLn == null)
    {
        throw new ArgumentException("传入数组不能为空");
    }

    int[] result = new int[SLm.Length + SLn.Length];
    int mIndex = 0;
    int nIndex = 0;
    for (int index = 0; index < result.Length; index++)
    {
        if (mIndex >= SLm.Length && nIndex >= SLn.Length)
        {
            break;
        }

        if (mIndex >= SLm.Length)
        {
            result[index] = SLn[nIndex++];
            continue;
        }

        if (nIndex >= SLn.Length)
        {
            result[index] = SLm[mIndex++];
            continue;
        }

        if (SLm[mIndex] < SLn[nIndex])
        {
            result[index] = SLm[mIndex++];
        }
        else if (SLm[mIndex] > SLn[nIndex])
        {
            result[index] = SLn[nIndex++];
        }
        else
        {
            result[index] = SLm[mIndex++];
            nIndex++;
        }
    }
    return result;
}

写第三题到一半的时候MM过来问了一下是否做完,估计自己应该能写出来,就说还要一回就好。现在已经忘记当初具体怎么写的了,不过肯定是完成了功能,还记得当时判断5和3不能相邻时用的技巧是:相邻的两个数字之和不能等于8。下面这个版本是根据http://blog.csdn.net/qianling3439/archive/2008/08/07/2781041.aspx 修改的C#版本:

public static void Main() 
{
    char[] number = new char[] { '1', '2', '2', '3', '4', '5' };  
    Func(number, 0, number.Length - 1);  
    Console.WriteLine(list.Count);  

    foreach (String s in list) 
    {  
        Console.Write(s + " ");  
    }  
}  

public static List<string> list = new List<string>();
public static void Func(char[] n, int beg, int end)
{  
    if (beg == end) 
    {
        string result = new string(n);
        if (result[2] == '4')  
            return;
        if (result.Contains("35") || result.Contains("53"))  
            return;
        list.Add(result); 
        return;  
    }  
    for (int i = beg; i <= end; i++) 
    {  
        Swap(n, beg, i);  
        Func(n, beg + 1, end);  
        Swap(n, beg, i);  
    }  
}  

public static void Swap(char[] n, int a, int b)
{  
    char temp = n[a];  
    n[a] = n[b];  
    n[b] = temp;  
} 

第二轮面试

答完题目之后,一个年轻人(25岁左右)给我面试,根据我的经验估计对方应该是项目小组中的技术骨干

1. ASP.NET页面生命周期
这个问题我本身比较熟悉,出门前还看过 :)。
说了几个自己认为比较重要的PreInit、LoadViewState、 LoadPostData、Load、RaisePostDataChangedEvent(所有实现了IPostBackDataHandler接口的控件)、RaisePostBackEvent(实现 IPostBackEventHandler 接口的控件,如 Button, LinkButton等)、PreRender、SaveViewState。当然包括每个事件主要做什么,尤其是LoadViewState和SaveViewState是实现ASP.NET了保持状态的假象。
(相信这个问题回答的超出对方想象)

2. 母版页的作用
这个问题比较简单,简单介绍并提及自己不喜欢用母版页,用javascript找控件比较麻烦,对方颇有同感。

3. 简单查询,考勤表id(PK int) name(varchar) time(datetime),求迟到次数最多的员工的最后一次迟到时间
答案就不贴了

4. 经典的第M条到第N条记录
先问了一下要SQL Server 2000还是SQL Server 2005的版本,对方马上笑了,说还是SQL Server 2000的吧,给了一个top的版本
(我的blog上写过类似的东东http://blog.csdn.net/amandag/archive/2008/07/14/2646472.aspx)

5. 算法:最长升序降序序列,7 5 6 8 10 7 9 3 8 7 4 1 8 9 4,则最长的升序序列为5, 6, 8, 10,最长的降序序列为8,7,4,1
个人的答案是用了一个循环,这里就不贴了。
顺便提一句,手写算法题的时候,对方会一直盯着看,压力比平时写程序大很多

6. 无限级分类数据库设计及节点查找
最近写了一篇类似的blog,当时的思想也差不多是这样
http://blog.csdn.net/amandag/archive/2009/12/16/5021126.aspx

7. 二叉树查找
个人感觉由于前面的问题回答的还不错,后面的这两个问题对方也只是要求我说了一下思想,并未写具体的代码

第三轮面试
面试官是一个年约28~29的女孩,问了一些关于我做的项目的问题,个人感觉她的技术不如前面一个面试官,而且表达思路也不是很清楚,略聊了一会对方告诉我下面会有项目经理面试。

第四轮面试
面试官应该是个技术性的PM,问了一下网站架构的问题,和其聊了一会数据处理中需要考虑的问题(并发、索引、安全、分布式、缓存、海量数据)。

做技术的还是比较坦诚,他认可我的技术水平(这点让我颇为开心),并建议我应聘PM的岗位(其实对方招聘的时候只有SDE、Senior SDE这两个岗位),此时我也意识到如果仅仅应聘Senior SDE看来并不匹配。

第五轮面试
面试官应该是个部门经理,很能聊,主要谈了两个问题
1. 如何控制项目管理中的风险(主要提到了项目进度的控制和客户的交流)
2. 如何打造一个高效的开发团队、如何评估你的团队开发人员
针对我的回答又问了些相关问题,说句老实话,对方显然很有经验,这轮不知深浅。

这轮结束后对方说公司的副总大概18:30左右会过来,问我是否介意等,我当然不介意。

第六轮面试
对方显然更有经验,感觉不到对方在问问题,基本就是在聊天,他的回答经常是笑着说"我了解了"或者"我明白了",我也只能见招拆招了,最后对方问了一下薪资的问题,我努力踢过去一个皮球,被对方轻易地踢了回来,只好先翻底牌了。

今天的面试总计用了大约6个小时。

结语

很多朋友很关心最终面试是否成功,要让大家失望了,最终我没有去这家公司,如果去了,怕也未必会发这个帖子。

没有去的原因有些不便说,可以提及的说一下。

面试结束后对方并没有给我回音,由于我有W公司另一个人事的MSN,所以托其问一下,对方给了回应,和我预期的情况差不多,薪资没谈拢(和我预期的有不少差距),我考虑再三(上班的车程大约要1个半小时,而我现在只需要40分钟),最终还是放弃了。

另:我咨询了一个朋友(Z公司的副总),讲述了一下我面试的经过,问下有何问题,朋友给我的解释也可能是为了安慰我,内容大致如下:
1. 对方本来没有打算招PM,但显然 Senior SDE和我并不匹配,所以我这个属于隐形招聘需求,对方最需要的并不是PM。
2. W公司现在招人是为了有可能接上政府的单子,项目还没接上,这个PM对W公司并不着急。

欢迎各位朋友对上述问题不吝指教!所有分数将给提出有价值的答案或者建议的朋友,谢谢!


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
每日一面 - 为何我们经常使用 2 的 N 次方作为分片数量?
每日一面 - 为何我们经常使用 2 的 N 次方作为分片数量?
27 0
SpringCloud升级之路2020.0.x版-5.所有项目的parent与spring-framework-common说明
SpringCloud升级之路2020.0.x版-5.所有项目的parent与spring-framework-common说明
16 0
Gitlab(2)- centos7.x 下安装社区版 Gitlab 以及它的配置管理 (下)
Gitlab(2)- centos7.x 下安装社区版 Gitlab 以及它的配置管理 (下)
31 0
《Kotin 极简教程》第7章 面向对象编程(OOP)(2)
《Kotlin极简教程》正式上架: 点击这里 > 去京东商城购买阅读 点击这里 > 去天猫商城购买阅读 非常感谢您亲爱的读者,大家请多支持!!!有任何问题,欢迎随时与我交流~ 7.8 注解类 Kotlin 的注解与 Java 的注解完全兼容。
1038 0
《Kotin 极简教程》第7章 面向对象编程(OOP)(1)
第7章 面向对象编程(OOP) 《Kotlin极简教程》正式上架: 点击这里 > 去京东商城购买阅读 点击这里 > 去天猫商城购买阅读 非常感谢您亲爱的读者,大家请多支持!!!有任何问题,欢迎随时与我交流~ 在前面的章节中,我们学习了Kotlin的语言基础知识、类型系统、集合类以及泛型相关的知识。
1219 0
CSDN社区分享面试经历活动作品27——java程序员求职总结
找工作已有半个月了,去了几家互联网或软件公司,诸如搜狐、人人、京东、华为等。回头一看,发现学到还不少,以前光顾着写代码,来不及注意到的地方都一一暴漏出来了。
1090 0
CSDN社区分享面试经历活动作品18——话说我的面试经历
当得知我考研失败后,我也没有心思去看书,去找工作了。我直接在家里玩了一个多月。后来我同学打电话给我说,快回来吧。学校要开始交毕业设计了。
1037 0
MFC与SDK中的重画问题 。。WM_PAINT消息的处理
  在基于多文档的应用程序  CView的重绘为例子SD   在 K中我们是拦截 WM_PAINT 消息进行 重回的处理 只要 窗体一出现Invalid Area 那么都需要重绘    在MFC中 WM_PAINT 消息的响应函数 是 OnPaint() 但是为什么重绘 我们一直在 O...
696 0
+关注
尚武科技
尚武集团专用阿里云账号!
24
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载