答:
string str = null; 定义了一个字符串对象,赋值为null也就是没有分配内存
string str=””分配了内存空间 ,值为空
string.empty 是系统预定义的一个空字符串对象(长度为0的字符串对象)已经分配内存了
答:C#仅是语言层面的,所以C#本身是存在指针类型的,可以引用指针。但在.net开发时,凡是使用指针、开辟内存等不受托管处理的都为非安全开发。也就是说,指针之类的引用在.net中必须加在unsafe关键词之词。而且在编译时也必须选中允许非安全编译才可以通过。
如果不在unsafe中,.net是不允许使用指针类型的。非安全程序的优点,性能较高,可以写较高性能的程序代码;但劣势也是十分明显——不支持移植性,GC甚至无法管理内存等系统资源等等。所以一般情况下不建议非安全编程,在安全编程中是不可以有指针等类型的!
答:三层架构辑层、数据访问层。区分层次的目的即为了“高内聚低耦合”的思想。在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。
答:C#可以直接对内存进行操作。但是默认情况下,为了保持类型安全,C#不支持指针运算。不过,通过使用 unsafe 关键字,可以定义可使用指针的不安全上下文。
答:所以sleep()和wait()方法的最大区别是:sleep()睡眠时,保持对象锁,仍然占有该锁;其他线程无法访问,而wait()睡眠时,释放对象锁。其他线程可以访问。
Int DataTime,在赋值时未给予赋值,此时系统会分配给它一个最小的时间,不会是null值,Int DataTime,不会有null类型,C#提供了“可空类型”这种语法,只要在类型后加?就构成了可空的数据类型,比如int?、bool?,这样int? i=null 就可以了
答:s1 + 1,s1是short类型,1是int型,s1会自动转换为int型的1,与1相加后,得到int型的2,要向左侧的short类型的s1看齐,即需要通过强制类型转换。正确写法:s1 = (short) (s1 + 1);
UDP是面向无连接的通讯协议,UDP数据包括目的端口号和源端口号信息。
优点:UDP速度快、操作简单、要求系统资源较少,由于通讯不需要连接,可以实现广播发送 缺点:UDP传送数据前并不与对方建立连接,对接收到的数据也不发送确认信号,发送端不知道数 据是否会正确接收,也不重复发送,不可靠。
TCP是面向连接的通讯协议,通过三次握手建立连接,通讯完成时四次握手
优点:TCP在数据传递时,有确认、窗口、重传、阻塞等控制机制,能保证数据正确性,较为可靠。
缺点:TCP相对于UDP速度慢一点,要求系统资源较多
答:如果在字符串常量池中不存在其代表的对象,就创建两个,如果存在就创建一个.
public int fn(n)
{
if(n<=2){
return 1
}
else{
return fn(n-1)+fn(n-2)
}
}复制代码
int[] list= { 5, 9, 15, 22, 30 }
public int[] fn(int[] list)
{
int temp=0;//用于进行交换的临时数
for(int i=0;i<=list.Length;i++){
for(int j=0;j list[j]) { temp = list[j - 1]; list[j - 1] = list[j]; list[j] = temp; }
}
}
return list;
}复制代码
答:
public string Name
{
get{
return name;
}
set
{
name = value;
}
}
复制代码
在set访问器中隐藏的参数名是value他的类型和声明的属性类型相同
Code-Behind技术 就是代码隐藏,在ASP.NET中通过ASPX页面指向CS文件的方法实现显示逻辑和处理逻辑的分离,这样有助于web应用程序的创建。比如分工,美工和编程的可以个干各的,不用再像以前asp那样都代码和html代码混在一起,难以维护
答:List
首先我们清楚List
而HashTable或者Dictionary,他是根据Key而根据Hash算法分析产生的内存地址,因此在宏观上是不连续的,虽然微软对其算法也进行了很大的优化。由于这样的不连续,在遍历时,Dictionary必然会产生大量的内存换页操作,而List只需要进行最少的内存换页即可,这就是List和Dictionary在遍历时效率差异的根本原因)
答:MVC是一种软件开发架构,它包含了很多的设计模式,最为密切是以下三种:观察者模式,组合模式和策略模式
MVC架构把数据处理,程序输入输出控制及数据显示分离开来,并且描述了不同部件的对象间的通信方式,使得软件可维护性,可扩展性,灵活性以及封装性大大提高。
MVC(Model-View-Controller)把系统的组成分解为M(模型)、V(视图)、C(控制器)三种部件。V(视图)表示数据在屏幕上的显示;C(控制器)提供处理过程控制,它在模型和视图之间起连接作用。控制器本身不输出任何信息和做任何处理,它只负责把用户的请求转成针对Model的操作,和调用相应的视图来显示Model处理后的数据。
答:
Response对象:Response对象是HttpResponse类的一个对象,与一个HTTP响应相对应,通过该对象的属性和方法可以控制如何将服务器端的数据发送到客户端浏览器
Request对象:Request对象是HttpRequest类的对象。当客户发出请求执行,客户端的请求信息会包装在Request对象中。这些请求信息包括请求头、请求方法(post,get)、提交的信息等
Server对象:Server对象的属性反应了Web服务器的各种信息,他提供了服务器可以提供的各种服务
Application对象:Application对象在实际网络开发中的用途就是记录整个网络的信息,如上线人数、在线名单、意见调查和网上选举等。在给定的应用程序的多有用户之间共享信息,并在服务器运行期间持久的保存数据
Session对象:内置对象Session负责存储、读取和改变一个特定用户的会话信息,对于每个用户的每次访问Session对象都是唯一的。
Cookie对象:在Web程序设计中,它表示一个长度不超过4k的文本文件,这个文件在用户的硬盘上,可以由Web浏览器进行访问
答:get请求会暴露用户请求的参数在url地址中,并且数据有大小限制,但是处理速度快
post请求不会暴露用户的请求参数,对数据没有大小限制,但是处理速度相对get请求较慢
答:WebService采用HTTP协议传输数据,采用XML格式封装数据。XML是WebService平台中表示数据的格式。除了易于建立和易于分析外,XML主要的优点在于它既是平台无关的,又是厂商无关的。无关性是比技术优越性更重要的,在开发过程中WebService向外界暴露出一个能通过Web进行调用的API,客户端可以通过请求这个接口来获取数据。实现前后端的分离加快开发效率
答:所谓SQL注入式攻击,就是攻击者把SQL命令插入到Web表单的输入域或页面请求的查询字符串,欺骗服务器执行恶意的SQL命令,从而对数据库的数据进行操作的一种攻击手段
1.进行字符替换,替换掉一些敏感字符
2.使用存储过程完成数据的查询
3.限制表单输入的字符长度
4.在后端对用户输入的信息校验合法性
5.检查提取数据的查询所返回的记录数量
6.将用户登录名称、密码等数据加密保存进行消毒处理
答:html 就是我们通常的说的 html 语言标记,这些语言标记在已往的静态页面和其他网页里存在,不能在服务器端控制的,只能在客户端通过 javascript等程序语言来控制
asp.net的服务器控件是运行在服务器上的,直接封装了操作该控件的方法,前后代码不分离
一个运行在客户端一个运行在服务端
答:
1.Request.QueryString:获取http查询字符串变量集合即Request.QueryString[string name]
2.Request.Form:获取窗体变量集合即Request.Form[string name]
3.Session:即Session["string"]=string
答:SOAP是Web Service的通信协议。当用户通过UDDI找到你的WSDL描述文档后,他通过可以SOAP调用你建立的Web服务中的一个或多个操作。SOAP是XML文档形式的调用方法的规范,可以支持不同的底层接口,像HTTP(S)或者SMTP。应用程序通过使用远程过程调用(RPC)在诸如 DCOM 与 CORBA 等对象之间进行通信的方式会产生兼容性以及安全问题;防火墙和代理服务器通常会阻止此类流量。通过 HTTP 在应用程序间通信是更好的方法,因为 HTTP 得到了所有的因特网浏览器及服务器的支持。SOAP 提供了一种标准的方法,使得运行在不同的操作系统并使用不同的技术和编程语言的应用程序可以互相进行通信。
答:
1、Connection(连接数据库)
2、Command(执行T-SQL语句)
3、DataAdapter(用户填充DataSet,断开模式)
4、DataReader(读取数据库,一种只读模式)
5、DataSet(数据集,好比电脑的内存)
欢迎关注我的博客:来和我一起成长吧
往期精彩好文:
【CEAC 之《.NET程序设计工程师》】【CEAC 之《企业信息化管理》】
【ASP.NET(C#) 面试总结面试题大全】【Vue·高频前端面试题汇总】
你们的点赞 收藏⭐ 留言 关注✅
是我持续创作,输出优质内容的最大动力!
谢谢!