asp.net高級(jí)圖文說明教程---對(duì)象
發(fā)表時(shí)間:2024-01-26 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]C#里的類(Class),也可以叫做對(duì)象(object),它由以下幾部分組成:成員變量,屬性和方法,其中必不可少的是這個(gè)類不帶任何參數(shù)的構(gòu)造函數(shù),它不指定返回類型,作用是初始化類的成員變量、分配內(nèi)存等。和c++不同,c#類只有構(gòu)造函數(shù),不需要析購函數(shù),也就是說你只需要為成員變量分配內(nèi)存,而不必要顯...
C#里的類(Class),也可以叫做對(duì)象(object),它由以下幾部分組成:成員變量,屬性和
方法,其中必不
可少的是這個(gè)類不帶任何參數(shù)的構(gòu)造函數(shù),它不指定返回類型,作用是初始化類的成員
變量、分配內(nèi)存等。和
c++不同,c#類只有構(gòu)造函數(shù),不需要析購函數(shù),也就是說你只需要為成員變量分配內(nèi)存
,而不必要顯式的釋
放內(nèi)存,這是因?yàn)閏#和java一樣都是通過垃圾收集器來釋放內(nèi)存。明白這些,我們就可
以構(gòu)造一個(gè)最簡單的
類,一個(gè)什么也不做的類:
public class MyClass
{
public MyClass(){} ;
}
要使用時(shí)只需要簡單的new一個(gè)出來就行了,象這樣:MyClass myClass1 = new
MyClass() ;不要懷疑,你的確已經(jīng)創(chuàng)建了一個(gè)對(duì)象,盡管它什么也不做:)。下面我們
給它加一個(gè)私有字符型成員變量m_strTitle,并且在構(gòu)造函數(shù)里初始化這個(gè)成員變量,
整個(gè)類的定義就變成這樣:
public class MyClass
{
//私有成員變量
private string m_strTitle ;
//構(gòu)造函數(shù)
public MyClass()
{
m_strTitle = "我已經(jīng)被賦初值了" ;
}
}
注意定義成員變量的這行代碼:private string m_strTitle ; 其中string好理解,說
明m_strTitle是
string類型的,那么最前面的private是什么作用呢?這個(gè)private(私有)說明這個(gè)成員
變量是私有的,只有這
個(gè)類內(nèi)部的函數(shù)可以使用,而其他任何地方包括子類的函數(shù)都不能使用它,除了private
,你還可以定義成
public(公共)和protected(保護(hù)),public表明這個(gè)成員變量在任何地方都可以使用,而
protected表明這個(gè)變
量只能在本類或子類中使用。所以,如果我們想要使用這個(gè)成員變量,可以把它定義成p
ublic,但對(duì)于面向?qū)?br>象編程來說這不是個(gè)好的編程習(xí)慣,因?yàn)樗茐牧祟惖姆庋b性,在c++里好的方法是再定
義公共函數(shù)來存取這
個(gè)私有變量,而c#里提供了一個(gè)更加方便的方法,那就是屬性(property),現(xiàn)在我們把
這個(gè)屬性Title加上:
public class MyClass
{
//私有成員變量
private string m_strTitle ;
//屬性
public string Title
{
get
{
return this.m_strTitle ;
}
set
{
this.m_strTitle = value ;
}
}
//構(gòu)造函數(shù)
public MyClass()
{
m_strTitle = "我已經(jīng)被賦初值了" ;
}
}
讓我們來看看如何定義屬性,首先同樣需要作用域限定符,通常我們使用public,表明
任何地方都可以使
用該屬性,其次有兩個(gè)關(guān)鍵字需要注意:this和value , this代表類本身,所以this.m_
strTitle就是代表本類的成員變量m_strTitle , value代表當(dāng)這個(gè)屬性作為左值時(shí)等號(hào)
右邊的值,象這樣:myClass.Title = "hello" , 那么value的值就是"hello" , 好了,
這個(gè)類已經(jīng)可以使用了,象下面:
public static void Main(String[] args)
{
MyClass myClass = new myClass() ; //構(gòu)造MyClass類的一個(gè)實(shí)例
Console.WriteLine(myClass.Title) ; //結(jié)果是:我已經(jīng)被賦初值了
myClass.Title = "我的值改變了" ; //改變Title屬性的值
Console.Writeline(myClass.Title) ; //這時(shí)結(jié)果變成:我的值改變了
}
好了,現(xiàn)在讓我們給這個(gè)類加上一個(gè)MyMethod方法,這個(gè)方法沒有返回值,帶一個(gè)字符
型參數(shù)。
public class MyClass
{
//私有成員變量
private string m_strTitle ;
//屬性
public string Title
{
get
{
return this.m_strTitle ;
}
set
{
this.m_strTitle = value ;
}
}
//構(gòu)造函數(shù)
public MyClass()
{
m_strTitle = "我已經(jīng)被賦初值了" ;
}
//方法
public void MyMethod(string a_str)
{
this.m_strTitle = a_str ;
}
}
這是我們可以改寫一下剛才那個(gè)程序,運(yùn)行結(jié)果同剛才一樣:
public static void Main(String[] args)
{
MyClass myClass = new myClass() ; //構(gòu)造MyClass類的一個(gè)實(shí)例
Console.WriteLine(myClass.Title) ; //結(jié)果是:我已經(jīng)被賦初值了
myClass.MyMethod( "我的值改變了" ); //改變Title屬性的值
Console.Writeline(myClass.Title) ; //這時(shí)結(jié)果變成:我的值改變了
}
以上簡單講了一下如何定義類,看完這些內(nèi)容,可能你就可以理解上一節(jié)我們構(gòu)造的那
個(gè)bbs對(duì)象,讓我們
再看一下它的定義:
namespace MyOwnClass
{
using System;
using System.Data.SQL ;
using System.Data ;
////////////////////////////////////////////////////////////////////
//
// Class Name : BBS
//
// Description: 論壇類,構(gòu)造一個(gè)論壇對(duì)象
//
// date: 2000/02/03
//
/// ////////////////////////////////////////////////////////////////
public class BBS
{
//私有變量
private string m_strTitle ; //bbs名稱
private int m_intForumCount ; //版面數(shù)
private int m_intTopicCount ; //貼子數(shù)
private int m_intUserCount ; //注冊(cè)用戶數(shù)
//屬性
public string Title
{
get
{
return m_strTitle ;
}
}
public int ForumCount
{
get
{
return m_intForumCount ;
}
}
public int TopicCount
{
get
{
return m_intTopicCount ;
}
}
public int UserCount
{
get
{
return m_intUserCount ;
}
}
//構(gòu)造函數(shù)
public BBS(string a_strTitle)
{
//
// TODO: Add Constructor Logic here
//
m_strTitle = a_strTitle ;
//讀取數(shù)據(jù)庫
MyConnection myConn = new MyConnection() ;
SQLCommand myCommand = new SQLCommand() ;
myCommand.ActiveConnection = myConn ;
myCommand.CommandText = "up_GetBBSInfo" ; //調(diào)用存儲(chǔ)過程
myCommand.CommandType = CommandType.StoredProcedure ;
try
{
myConn.Open() ;
SQLDataReader myReader ;
myCommand.Execute(out myReader) ;
if (myReader.Read())
{
m_intForumCount = (int)myReader["ForumCount"] ;
m_intTopicCount = (int)myReader["TopicCount"] ;
m_intUserCount = (int)myReader["UserCount"] ;
}
else
{
throw(new Exception("表或存儲(chǔ)過程不存在")) ;
}
//清場(chǎng)
myReader.Close();
myConn.Close() ;
}
catch(SQLException e)
{
throw(new Exception("數(shù)據(jù)庫出錯(cuò):" + e.Message)) ;
}
}
}
}