c#语言asp.net实现treeview控件读数据库动态生成树的代码

c#语言asp.net实现treeview控件读数据库动态生成树的代码,第1张

DLL三个字母对于你来说一定很熟悉吧,它是Dynamic Link Library 的缩写形式,函数的可执行代码位于一个 DLL 中,该 DLL 包含一个或多个已被编译、链接并与使用它们的进程分开存储的函数。DLL 还有助于共享数据和资源。多个应用程序可同时访问内存中单个 DLL 副本的内容。

动态链接库是一个能够被应用程序和其它的DLL调用的过程和函数的集合体,它里面包含的是公共代码或资源。由于DLL代码使用了内存共享技术,在某些地方windows也给了DLL一些更高的权限,因而DLL中可以实现一些一般程序所不能实现的功能,如实现windows的HOOK、ISAPI等。

同时,DLL还为不同语言间代码共享提供了一条方便的途径。因而DLL在编程时应用较为广泛,本文将介绍如何在 Delphi 中建立和使用DLL。

从使用效果看,DLL和unit 很像,它们都可以被别的工程模块所调用,但二者在内部的实现机制上确存在着差别。如果一个程序模块中用uses语句引用了某个unit,编译程序在编译该模块时,便会连同unit一起编译,并把编译后的可执行代码链接到本程序模块中,这就是一个程序模块能够调用所引用unit中过程和函数的原因。

当同一个unit被多个工程所引用时,则每个工程中都含有该unit的可执行代码,当含有该unit的多个工程同时执行时,unit的可执行代码会随不同工程而多次被调入内存,造成内存资源的浪费。DLL则不同,它即使被某个工程调用,编译后仍是独立的。

也就是说编译后,一个DLL库形成一个单独的可执行文件,而不与任何其它的可执行文件连接在一起,因而DLL库并不从属于某个特定的工程,当多个工程调用同一个DLL库时只有第一个工程把DLL库调入内存,其余工程并不重复调入同一个DLL库到内存,而是到同一个共享内存区读取。并且,DLL的执行代码是在程序运行期间动态调入的,而不是如unit在程序运行时就与整个工程一起调入内存。这样便可消除unit带来的相同代码多处占用内存的弊病。Delphi中DLL库的建立

在Delphi环境中,编写一个DLL同编写一个一般的应用程序并没有太大的区别。事实上作为DLL主体的DLL函数的编写,除了在内存、资源的管理上有所不同外,并不需要其它特别的手段。

一般工程文件的格式为:

program 工程标题;

uses 子句;

程序体

而DLLs工程文件的格式为:

library 工程标题;

uses 子句;

exprots 子句; 1一般工程文件的头标用program关键字,而DLL工程文件头标用library 关键字。不同的关键字通知编译器生成不同的可执行文件。用program关键字生成的是exe文件,而用library关键字生成的是dll文件;

2假如DLL要输出供其它应用程序使用的函数或过程,则必须将这些函数或过程列在exports子句中。而这些函数或过程本身必须用export编译指令进行编译。 在Delphi主菜单file 中选new项,在d出的窗口中双击DLL图标,便会自动给出DLL源模块框架,如下:

Library project1;

{注释}

uses

SysUtils, Classes;

begin

end

接下来便可在USES和begin之间加入想在该DLL中实现的过程和函数的定义,并用export和exprots保字把它们引出,以便别的模块引用,在begin和end之间加入初始化代码,初始化代码是用来对DLL变量初始化的。应注意,即便无初始化代码begin与end也不可省略,如下例:

library minmax;

function Min(X, Y: Integer): Integer; export;

begin

if X < Y then Min := X else Min := Y;

end;

function Max(X, Y: Integer): Integer; export;

begin

if X > Y then Max := X else Max := Y;

end;

exports

Min index 1,

Max index 2;

begin

end

经编译后,并以minmaxDLL存盘后,一个DLL库文件便形成了。 访问DLL库有两种方式,一种是静态引用,另一种是动态引用。

用静态引用这种方法装入DLL要做两件事情:为DLL 库创建一个输入单元,以及用USES把输入单元连接到要使用DLL 函数的程序模块中。为DLL库创建的输入单元与普通的单元的区别仅在于:在它的接口处声明的过程、函数,并不在它的实现部分给出真正的实现代码,而是用external关键字把过程、函数的实现细节委托给外部DLL模块。

external命令的使用语法如下:

procedure /function 过程/函数名;external DLL模块名;

下面给出为上面创建的minmaxDLL库写的输入单元源文件testdll pas,从中可看出输入单元与一般单元的一些差别,代码如下所示:

unit testdll;

interface

uses

function Min (X, Y: Integer): Integer;

function Max (X, Y: Integer): Integer;

implementation

function Min; external ‘minmaxDLL’;

function Max; external ‘minmaxDLL’;

end

一个应用程序若想调用minmaxDLL中的函数,只须在其uses语句中加入testdll 单元即可。

动态装入DLL,要用到Windows的三个API函数。Loadlibrary、Freelibrary和GetprocAddress 。 loadlibrary函数用来装入DLL库,其调用格式如下:

function loadlobrary (DLLfileName:Pchar): THandle:

当不再需要一个DLL库时,应调用FreeLibrary函数将其释放,以空出宝贵的内存资源,其调用格式如下:

procedure FreeLibrary (Libmodule:THandle)

Libmodule 为由LoadLibrary调用得到的DLL库句柄。在用loadlobrary 函数装入某个DLL库和调用FreeLibrary释放该DLL库之间的程序段中, 可以使用该DLL库中的过程和函数,具体使用方法是:用GetprocAddress函数把DLL库中函数的地址传递给程序中某个函数变量,再用该变量实现DLL函数的调用。GetprocAddress函数声名如下

function GetprocAddress (Libmodule:THandle:procname:pchar):TFarProc:

如下例所示:

type

TTimeRec = record

Second: Integer;

Minute: Integer;

Hour: Integer;

end;

TGetTime = procedure(var Time: TTimeRec);

THandle = Integer;

var

Time: TTimeRec;

Handle: THandle;

GetTime: TGetTime;

begin

Handle := LoadLibrary('DATETIMEDLL');

if Handle <> 0 then

begin

@GetTime := GetProcAddress(Handle, 'GetTime');

if @GetTime <> nil then

begin

GetTime(Time);

with Time do

WriteLn('The time is ', Hour, ':', Minute, ':', Second);

end;

FreeLibrary(Handle);

end;

end;

在调用动态链接库时应注意, 所需动态链接库须与应用程序在同一目录或Windows System 目录下。

动态链接库是 Windows下程序组织的一种重要方式,使用动态链接库可以极大地保护用户在不同开发工具、不同时期所做的工作,提高编程效率。

复选框代码

<input type="checkbox" name="checkdel" value=<%=(rsFieldsItem("id")Value)%>>

处理页代码(删除记录,以供参考)

<%

id=Trim(Request("Checkdel"))

if id="" then

responsewrite "来源未知或数据丢失!"

responseend

end if

id=split(id,",",-1,1) '获取ID,主要在这

for i=0 to UBound(id)

connexecute("delete from ip where id="&id(i))

next

connclose '关闭数据库链接

set conn=nothing

%>

你可以在自己的bin目录下新建文件(如txt,dat,ini,config都可以)

我这边以ini为例说下:

( 下面等号右边的 DataSource = D:\zmd\自己的例子ileLostOrNot\frmDataBaseChange\bin\Debug\Data\地质灾害查询统计数据库mdb 这

里是我的数据库的绝对路径,(用户)要修改就是在这里(修改成自己的~~,很方便的~))

--------------------------------------------------你在ini文件中写如下代码,从下行开始复制,这行不要

;用户自行连接字符串strConnetion

[UserManagestrConnetion]

Source =D:\zmd\自己的例子\FileLostOrNot\frmDataBaseChange\bin\Debug\Data\地质灾害查询统计数据库mdb

-----------------------------------------------------------------------------------到上面为止,这行不要

下面是你程序中的代码:

首先引用中添加(Ninidll)文件(没有可以找我要,也可以自己去下),再引用空间

using NiniConfig;

using SystemDataSqlClient;

某个事件中添加如下代码:

string configfile = ApplicationStartupPath + @"\iTelluroGlobeEngineini";

IConfigSource ConfigSource = new IniConfigSource(configfile);

string strSource = ConfigSourceConfigs["UserManagestrConnetion"]Get("Source");

string sqlConnectionString="server=(local);"+"integrated security=SSPI;"+"database=" + strSource ;//这个连接字符串不知道对不,我一般用的都Access的

(string SqlConnectionString = "Provider=MicrosoftJetOLEDB40;Data Source=" + strSource ;//我连接的是Access的数据库,你自己修改下连接字符串吧)

SqlConnection sqlCon= new SqlConnection(SqlConnectionString);

sqlConOpen();

//下面的你应该很熟习

DataSet ds = new DataSet();

SqlDataAdapter da = new SqlDataAdapter("自己的sql查询语句", sqlCon);

daFill(ds);

你先试下吧,不行的话,可以在hi我~~

以上就是关于c#语言asp.net实现treeview控件读数据库动态生成树的代码全部的内容,包括:c#语言asp.net实现treeview控件读数据库动态生成树的代码、html怎么获取动态数据、动态数据库的什么是动态链接库等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9510902.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存