C#中,Application.Exit()和Close()有什么不同。

dlmeijianyu 2008-09-26 12:51:25
Application.Exit()和this.close有什么不同,能不能给出详细的解释。
我在用的过程发现:this.Close关闭的是当前窗体。Application.Exit如果是代码的最后,则可以关闭所有的窗体,如果后面还有别代码,则会继续往下执行。
...全文
845 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
ziyan688999 2010-04-10
  • 打赏
  • 举报
回复
非常好。学习
whitechololate 2008-09-26
  • 打赏
  • 举报
回复
关闭当前窗体 this.Close(); //
Application.Exit();关闭当前窗体并结束当前程序的运行 }

Application.Exit 方法
通知所有消息泵必须终止,并且在处理了消息以后关闭所有应用程序窗口。

Form.Close 方法
关闭窗体。

如果该窗体是应用程序的主启动窗体,则調用窗体的Close()方法,跟調用Application.Exit的效果差不多。
如果该窗体非主启动窗体,则只是关闭该窗体而不关闭整个应用程序。

如果是多线程应用程序,要想关闭整个应用程序,除了調用Application.Exit()方法或者主启动窗体的Close()之外,还需要显示的調用终止线程的代码。否则窗体虽然关闭了,看似应用程序退出了,其实线程依然还驻留在内存中工作。打开任务管理器依然可以看到。

Application.Exit 方法
通知所有消息泵必须终止,并且在处理了消息以后关闭所有应用程序窗口。

该方法停止在所有线程上运行的所有消息循环,并关闭应用程序的所有窗口。该方法并不强制应用程序退出。Exit 方法通常从一个消息循环内调用,该方法强制 Run 返回。若要只退出当前线程的某个消息循环,请调用 ExitThread。

警告 当调用 Application.Exit 方法以退出应用程序时,不引发 Form.Closed 和 Form.Closing 事件。如果在必须执行的其中一个事件中有验证代码,则在调用 Exit 方法之前,应分别为每个打开的窗体调用 Form.Close 方法。


windows运行和初始化后,就进入消息循环,既然exit强制run返回那程序也就结束了,就会调用析够函数释放内存


Form.Close 方法

关闭窗体。 窗体关闭后,关闭在该对象内创建的所有资源并且释放该窗体,如果要关闭的窗体是应用程序的启动窗体,则该应用程序结束。

Close 时不释放窗体的一种情况是,窗体属于多文档界面 (MDI) 应用程序的一部分且是不可见的。在这种情况下,您需要手动调用 Dispose,将窗体的所有控件都标记为进行垃圾回收。

.net的垃圾回收是windows自己判断的,每过一段时间才自己回收,所以,.net程序占用内存异常大,除非你自己写析够函数和 Dispose释放资源


Application.SetCompatibleTextRenderingDefault方法

将某些控件上定义的 UseCompatibleTextRendering 属性设置为应用程序范围内的默认值。

某些 Windows 窗体控件可以使用 GDI 图形库或更新的 GDI+ 库来呈现其文本。由于 GDI+ 的性能和本地化问题而做出这样的更改。默认情况下,将支持 UseCompatibleTextRendering 属性的现有控件设置为 true 以获得向后兼容性,但 Visual Studio 等环境中的所有新控件都将该属性设置为 false。要切换新控件的默认文本呈现时,请使用 SetCompatibleTextRenderingDefault。


参数
defaultValue
用于新控件的默认值。如果为 true,则支持 UseCompatibleTextRendering 的新控件将 GDI+ 用于文本呈现;如果为 false,则新控件使用 GDI+。


如果在另一个应用程序中承载 Windows 窗体代码,例如 Internet Explorer,切勿调用该方法。仅在独立的 Windows 窗体应用程序中调用该方法。


MSDN文
yilanwuyu123 2008-09-26
  • 打赏
  • 举报
回复

//这个就不运行下面的了
Application.ExitThread();
zxm474493784 2008-09-26
  • 打赏
  • 举报
回复
Application.Exit()//关闭整个应用程序
this.close()//关闭当前窗体
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; namespace 图书管理系统 { public partial class 登录窗口 : Form { //public static string ConnectionString = "Server=(local);database=图书管理库;uid=sa;pwd=1234"; //sql server 混合模式 // public static string ConnectionString = "Server=(local);Integrated Security=SSPI;database=图书管理库"; //windows模式 public string strSQL; public SqlConnection myConnection; public SqlCommandBuilder sqlCmdBld; public DataSet ds = new DataSet(); public SqlDataAdapter da; public int num=0; private DataTable myTable; private DataRow myRow; public static string strUser; public static string strPassword; // public static string strDepartment; public static bool login_flag = false; public 登录窗口() { InitializeComponent(); } private void button2_Click(object sender, EventArgs e) { Close(); } private void 登录窗口_Load(object sender, EventArgs e) { linkdatabase link = new linkdatabase(); //实例化 myConnection = new SqlConnection(link.connectionstring()); //实例化连接 strSQL = "select * from 用户表 "; da = new SqlDataAdapter(strSQL, myConnection); ds.Clear(); da.Fill(ds, "用户表"); //////动作 myTable = ds.Tables["用户表"]; for (int i = 0; i < myTable.Rows.Count; i++) { comboBox1.Items.Add(myTable.Rows[i]["用户名"].ToString().Trim()); } } private void button1_Click(object sender, EventArgs e) { linkdatabase link = new linkdatabase(); //实例化 myConnection = new SqlConnection(link.connectionstring()); //实例化连接 strSQL = "sele
企业客户资源管理系统 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; namespace CRM { public partial class frmLogin : Form { public static string M_str_name;//记录登录用户名字 public static string M_str_pwd;//记录登录用户密码 public static string M_str_right;//记录登录用户的权限 CRM.BaseClass.BaseOperate boperate = new CRM.BaseClass.BaseOperate(); CRM.BaseClass.OperateAndValidate opAndvalidate = new CRM.BaseClass.OperateAndValidate(); public frmLogin() { InitializeComponent(); } private void frmLogin_Load(object sender, EventArgs e) { opAndvalidate.cboxBind(\"select UserName from tb_User\", \"tb_User\", \"UserName\", cboxUName); } private void cboxUName_SelectedIndexChanged(object sender, EventArgs e) { SqlDataReader sqlread = boperate.getread(\"select UserName,UserRight from tb_User where UserName=\'\" + cboxUName.Text + \"\'\"); if (sqlread.Read()) { labURight.Text = sqlread[\"UserRight\"].ToString(); M_str_right = labURight.Text; } sqlread.Close(); } private void btnLogin_Click(object sender, EventArgs e) { SqlDataReader sqlread=boperate.getread(\"select UserName,UserPwd from tb_User where UserName=\'\"+cboxUName.Text.Trim()+\"\' and UserPwd=\'\"+txtPwd.Text.Trim()+\"\'\"); sqlread.Read(); if (sqlread.HasRows) { M_str_name = cboxUName.Text; M_str_pwd = txtPwd.Text.Trim(); frmMain fmain = new frmMain(); this.Hide(); fmain.Show(); } else { MessageBox.Show(\"用户名或密码错误!\", \"提示\", MessageBoxButtons.OK, MessageBoxIcon.Information); txtPwd.Text = \"\"; cboxUName.Focus(); } sqlread.Close(); } private void btnExit_Click(object sender, EventArgs e) { Application.Exit(); } private void frmLogin_FormClosing(object sender, FormClosingEventArgs e) { Application.Exit(); } } }

110,537

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧