100165597.htm

来自「C#高级编程(第三版),顶死你们。。 。up」· HTM 代码 · 共 138 行 · 第 1/2 页

HTM
138
字号


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>
	
        21.2.1  高效地使用连接
</title></head>
<body>
    <div class="area">

        

        <div class="col1">
            <div class="lineBlue">
            </div>
            <!-- title -->
            <div class="arcTitle">
                <h1>
                    <a href="../16">
                        C#高级编程(第3版)
                    </a>
                </h1>
                <div style="text-align: center; font-size: 15px">
                    <a href="100165597.htm">
                        21.2.1  高效地使用连接
                    </a>
                </div>
                <div style="text-align: center; font-size: 15px">
                    <a class="url" href="../../default.htm">http://book.csdn.net/</a>
                    2006-10-13 14:41:00
                </div>
                <div style="margin: 0px auto; width: 700px; border: solid 1px #0b5f98;">
                    <div style="float: left; width: 16px; background-color: #0b5f98; color: White; padding: 1px;">
                        图书导读
                    </div>
                    <div style="float: right; width: 670px; text-align: left; line-height: 16pt; padding-left: 2px">
                        <!--导读-->
                        <h1 id="divCurrentNode" style="color: #b83507; width: 100%; text-align: left; font-size: 12px; padding-left: 2px">当前章节:<a href='100165597.htm'><font color='red'>21.2.1  高效地使用连接</font></a></h1>
                        <div id="divRelateNode" style="padding-left: 2px">
                        <div style='float:left;width:49%'>·<a href='100165594.htm'>21.1.2  共享类</a></div><div style='float:right;width:49%'>·<a href='100165595.htm'>21.1.3  数据库特定的类</a></div><div style='float:left;width:49%'>·<a href='100165596.htm'>21.2  使用数据库连接</a></div><div style='float:right;width:49%'>·<a href='100165598.htm'>21.2.2  事务处理</a></div><div style='float:left;width:49%'>·<a href='100165599.htm'>21.3  命令</a></div><div style='float:right;width:49%'>·<a href='100165600.htm'>21.3.1  执行命令</a></div></div>
                    </div>
                </div>
                </div>
            <!-- main -->
            <div id="main">
                <div id="text">
                  <div id="csdn_zhaig_ad_yahoo_2"></div>
                  
                 <link href="css.css" rel="stylesheet" type="text/css" /><h3 style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 0cm; MARGIN-RIGHT: 0cm; FTEL: 8.15pt"><a ftel="_Toc536518865"><span lang="EN-US">21.2.1&nbsp; </span></a><span style="FONT-FAMILY: 黑体">高效地使用连接</span></h3>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">一般情况下,当在</span><span lang="EN-US">.NET</span><span style="FONT-FAMILY: 宋体">中使用&ldquo;稀缺&rdquo;的资源时,例如数据库连接、窗口或图形对象,最好确保每个资源在使用后立即关闭。尽管</span><span lang="EN-US">.NET</span><span style="FONT-FAMILY: 宋体">的设计人员实现了自动的垃圾收集,垃圾最终都会被回收,但仍需要尽可能早地释放资源,以避免出现资源匮乏的情况。</span><span lang="EN-US">&nbsp;</span></p>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">当编写访问数据库的代码时,这是非常明显的,因为使连接打开的时间略长于需要的时间,就可能影响其他会话。在极端的情况下,不关闭连接会使其他用户无法进入一整组数据表,极大地降低了应用程序的性能。关闭数据库连接应是强制的,所以本节讨论如何构建代码,把一直打开资源的风险降到最低。</span></p>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">主要有两种方式可以确保数据库连接等类似的&ldquo;稀缺&rdquo;资源在使用后立即释放。</span></p>
<h4 style="FTEL: 21.45pt"><a ftel="_Toc536518866"><span lang="EN-US">1. </span></a><span style="FONT-FAMILY: 黑体">第一种方式</span><span style="FONT-FAMILY: 黑体; LETTER-SPACING: -1pt">&mdash;&mdash;</span><span style="LETTER-SPACING: -1pt"> </span><span style="FONT-FAMILY: 黑体; LETTER-SPACING: -1pt">利用</span><span lang="EN-US">try<sup>&hellip;</sup>catch<sup>&hellip;</sup>finally</span><span style="FONT-FAMILY: 黑体">语句块</span></h4>
<p class="MsoNormal"><span style="FONT-FAMILY: 宋体">确保释放资源的第一种方式是利用</span><span lang="EN-US">try<sup>&hellip;</sup>catch<sup>&hellip;</sup>finally</span><span style="FONT-FAMILY: 宋体">块,确保在</span><span lang="EN-US">finally</span><span style="FONT-FAMILY: 宋体">块中关闭任何已打开的连接。下面是一个小示例:</span></p>
<p class="2" style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-US">try</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">{</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; // Open the connection</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; conn.Open();</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; // Do something useful</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">}</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">catch ( Exception ex )</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">{</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; // Do something about the exception</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">}</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">finally</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">{</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; // Ensure that the connection is freed</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; LINE-HEIGHT: 13pt; FTEL: 18.45pt"><span lang="EN-US">&nbsp;&nbsp; conn.Close ( ) ;</span></p>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?