SharePoint性能总结和一些开发经验(3)
2010-10-22 15:00
288 查看
(7)
如果我们使用了
SPSite
的
LockIssue
、
Owner
、
SecondaryContact
属性的时候,会隐式的调用
RootWeb
属性,那么这样我们必须对
rootweb
这个对象进行释放。例如:
SPSite site = new SPSite(serverUrl);
String str = Site.LockIssue;
Site.RootWeb.Dispose();
Site.Dispose();
当
web
的
ParentWeb
属性为空的时候,我们使用的时候会调用
OpenWeb
方法来返回一个
SPWeb
对象,所以在程序最好释放
ParentWeb
的时候,我们需要判断一下
ParentWeb
对象是否为
null,
如果不为
Null
那就要对其进行释放。
(8)
当我们在
try-catch-finally
中使用
Response.Redirect()
方法进行页面重定向的时候,程序不会执行
finally
中的代码。因为在
try
中执行一个页面重定向的方法,会导致这个线程结束,并且产生一个异常,并且这个异常将会被运行时捕获,导致不会指定
finally
里面的代码。所以建议我们有页面跳转的时候要使用
Using
来释放相应的资源。例如:
不建议使用的方法
SPSite site = null
Try
{
Site = new SPSite(“http://serverurl”);
Response.Redirect(destUrl);
}
Catch
{}
Finally
{
If(site != null)
{
Site.Dispose();
}
}
建议使用的方法
Using(SPSite site = new SPSite(“http://serverurl”))
{
Response.Redirect(url);
}
如果坚持使用
try-catch-finally
那就必须在页面定向之前对非托管对象进行释放,例如:
SPSite site = null
Try
{
Site = new SPSite(“http://serverurl”);
Site.Dispose();
Response.Redirect(destUrl);
}
Catch
{}
Finally
{
If(site != null)
{
Site.Dispose();
}
}
(9)
我们使用
UserProfile
的时候可以返回一个
PersonalSite
,这个
PersonalSite
也是需要释放的
void PersonalSiteLeak()
{
using (SPSite siteCollection = new SPSite("http://moss"))
{
UserProfileManager profileManager = new UserProfileManager(ServerContext.GetContext(siteCollection));
UserProfile profile = profileManager.GetUserProfile("domain//username");
SPSite personalSite = profile.PersonalSite;
//
需要释放
personalSite.Dispose();
}
}
18.
调用
COM
需要手动释放资源
我们使用
Trados SDK
是以
COM
的形式进行调用的,所以在这里存在一个对
COM
对象进行资源释放的问题,因为
COM
对象不会自己进行资源释放,我们只能通过显示的调用
GC
进行资源回收。例如:
Application app = new Application();
Marshal.FinalReleaseComObject(app);
app = null;
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
GC.WaitForPendingFinalizers();
这里需要进行两次调用
GC.Collect();
GC.WaitForPendingFinalizers();
因为第一次只是对未释放的资源的统计,第二次才是真正的释放。第一次就是看有哪些
COM
对象的资源没有释放,而在第二则是根据第一次统计的结果进行对
COM
资源的回收。
19.
SharePoint Dispose Check Tool(
内存泄漏代码检查工具
)
主要用来检查我们编写的
exe
或是
dll
文件内部是否有
SharePoint
对象使用的内存泄漏,可以在
http://code.msdn.microsoft.com/SPDisposeCheck
站点进行下载。
具体的使用方法:
安装这个检查工具,然后使用命令行运行这个
exe,
然后将要检查的
exe
或是
dll
拷贝到这个工具的安装路径下面,然后在这个
SPDisposeCheck.exe sample.dll
命令进行检查。
20.
对于我们的系统,要有严格的异常处理机制和日志输出。
在
程序中输出日志,日志可以跟踪程序运行,当程序运行到一个地方,输出相应的日志,这样我们就可以根据日志的显示情况,知道程序运行的情况。方便定位程序出
错的位置和修改。现在我们可以在服务器上直接调试,但是如果我们的系统做成产品,卖给客户的时候,我们是不可能在客户的环境上进行调试的,所以系统日志是
必不可少的。主要是为了方便查找错误,然后解决问题。如果客户环境上出现问题,我们可以让客户将系统运行的日志给我们返回,这样我们可以根据日志就可以之
后系统在客户端运行出现了什么错误,然后给予相应的解决方法即可。
如果我们使用了
SPSite
的
LockIssue
、
Owner
、
SecondaryContact
属性的时候,会隐式的调用
RootWeb
属性,那么这样我们必须对
rootweb
这个对象进行释放。例如:
SPSite site = new SPSite(serverUrl);
String str = Site.LockIssue;
Site.RootWeb.Dispose();
Site.Dispose();
当
web
的
ParentWeb
属性为空的时候,我们使用的时候会调用
OpenWeb
方法来返回一个
SPWeb
对象,所以在程序最好释放
ParentWeb
的时候,我们需要判断一下
ParentWeb
对象是否为
null,
如果不为
Null
那就要对其进行释放。
(8)
当我们在
try-catch-finally
中使用
Response.Redirect()
方法进行页面重定向的时候,程序不会执行
finally
中的代码。因为在
try
中执行一个页面重定向的方法,会导致这个线程结束,并且产生一个异常,并且这个异常将会被运行时捕获,导致不会指定
finally
里面的代码。所以建议我们有页面跳转的时候要使用
Using
来释放相应的资源。例如:
不建议使用的方法
SPSite site = null
Try
{
Site = new SPSite(“http://serverurl”);
Response.Redirect(destUrl);
}
Catch
{}
Finally
{
If(site != null)
{
Site.Dispose();
}
}
建议使用的方法
Using(SPSite site = new SPSite(“http://serverurl”))
{
Response.Redirect(url);
}
如果坚持使用
try-catch-finally
那就必须在页面定向之前对非托管对象进行释放,例如:
SPSite site = null
Try
{
Site = new SPSite(“http://serverurl”);
Site.Dispose();
Response.Redirect(destUrl);
}
Catch
{}
Finally
{
If(site != null)
{
Site.Dispose();
}
}
(9)
我们使用
UserProfile
的时候可以返回一个
PersonalSite
,这个
PersonalSite
也是需要释放的
void PersonalSiteLeak()
{
using (SPSite siteCollection = new SPSite("http://moss"))
{
UserProfileManager profileManager = new UserProfileManager(ServerContext.GetContext(siteCollection));
UserProfile profile = profileManager.GetUserProfile("domain//username");
SPSite personalSite = profile.PersonalSite;
//
需要释放
personalSite.Dispose();
}
}
18.
调用
COM
需要手动释放资源
我们使用
Trados SDK
是以
COM
的形式进行调用的,所以在这里存在一个对
COM
对象进行资源释放的问题,因为
COM
对象不会自己进行资源释放,我们只能通过显示的调用
GC
进行资源回收。例如:
Application app = new Application();
Marshal.FinalReleaseComObject(app);
app = null;
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
GC.WaitForPendingFinalizers();
这里需要进行两次调用
GC.Collect();
GC.WaitForPendingFinalizers();
因为第一次只是对未释放的资源的统计,第二次才是真正的释放。第一次就是看有哪些
COM
对象的资源没有释放,而在第二则是根据第一次统计的结果进行对
COM
资源的回收。
19.
SharePoint Dispose Check Tool(
内存泄漏代码检查工具
)
主要用来检查我们编写的
exe
或是
dll
文件内部是否有
SharePoint
对象使用的内存泄漏,可以在
http://code.msdn.microsoft.com/SPDisposeCheck
站点进行下载。
具体的使用方法:
安装这个检查工具,然后使用命令行运行这个
exe,
然后将要检查的
exe
或是
dll
拷贝到这个工具的安装路径下面,然后在这个
SPDisposeCheck.exe sample.dll
命令进行检查。
20.
对于我们的系统,要有严格的异常处理机制和日志输出。
在
程序中输出日志,日志可以跟踪程序运行,当程序运行到一个地方,输出相应的日志,这样我们就可以根据日志的显示情况,知道程序运行的情况。方便定位程序出
错的位置和修改。现在我们可以在服务器上直接调试,但是如果我们的系统做成产品,卖给客户的时候,我们是不可能在客户的环境上进行调试的,所以系统日志是
必不可少的。主要是为了方便查找错误,然后解决问题。如果客户环境上出现问题,我们可以让客户将系统运行的日志给我们返回,这样我们可以根据日志就可以之
后系统在客户端运行出现了什么错误,然后给予相应的解决方法即可。
相关文章推荐
- SharePoint性能总结和一些开发经验(1)
- SharePoint性能总结和一些开发经验
- SharePoint性能总结和一些开发经验(3)
- SharePoint性能总结和一些开发经验(1)
- SharePoint性能总结和一些开发经验(1)
- SharePoint性能总结和一些开发经验(2)
- SharePoint性能总结和一些开发经验(2)
- SharePoint性能总结和一些开发经验(4)
- SharePoint性能总结和一些开发经验(4)
- 对DNT二次开发的一些经验总结!
- 安卓开发35:一些安卓设计经验总结
- android开发之gridView的一些属性。(项目经验总结)
- 开发Web App的一些工具和经验总结
- 对于 iOS 开发基于经验的一些总结与规划
- 对于 iOS 开发基于经验的一些总结与规划 (转载侵删)
- 开发经验!嵌入式硬件设计需要考虑的一些问题总结
- ATL 开发 COM 过程中的一些经验、问题总结
- android 开发中总结的一些经验
- Hybrid APP混合开发的一些经验和总结
- 对于 iOS 开发基于经验的一些总结与规划