Surfer Grid 明码文件(ASCII)格式解析

最近有一批数据需要处理,格式为Surfer Grid明码文件(*.grd),用记事本打开后发现文件格式比较简单,无论用程序去读还是经过简单处理后导入到Excel中、GIS软件中都比较方便,在这里就这类文件做一下格式说明。

Oracle透明网关配置过程中遇到的两个问题

Oracle透明网关(Transparent Gateway)能够方便地解决异构数据库系统之间的数据共享问题,使得基于Oracle环境的应用系统/程序在访问非Oracle数据库中的数据时不需要另外再做代码开发工作,大大节省系统开销,提高数据使用的灵活性(功能示意图如下)。最近在进行透明网关的安装和配置过程中遇到了两个问题,网上搜不到解决方案,摸索着解决后写此文总结一下,希望能对遇到同样问题的童鞋有所帮助。

Oracle 9i透明网关访问SQL Server

Oracle的透明网关是oracle直接访问异构数据库的利器。在9i中,透明网关是包含在数据库安装程序中的,在安装数据库软件过程中可以选择,透明网关可以安装在Oracle DB或者SQL Server DB所在的服务器中,也可以单独安装在二者以外的一台服务器中,看自己的需求如何了。需要说明的是Oracle 9i透明网关不能安装在Windows Server 2008、Win7和Linux等系统中,所以安装前请确定兼容性是没问题的。

【C#】一个非常好用的Word操作类

之前在网上搜过很多Word操作类,总没有非常满意的,于是自己封装了这个Word操作类,现在一直在用,根据自己的需要扩充了许多函数,可以满足大多数对Word操作的需求,如打开、创建Word文档、修改页眉页脚、插入表格、插入文字、文字格式化、查找替换、页边距设置、页面方向设置、插入分页符等等,相信会对许多人能有所帮助。

文章下方有下载链接。

WordEditClass

下载:WordEditClass.cs (796)

 

【ArcGIS二次开发】多图层查询要素并单独显示

需求举例:

如果我们有三年的空间数据存放在三个不同图层中,现在通过编写程序设定好了所需要素的属性条件和空间条件,查询出三个图层中满足这些条件的要素,并高亮显示在已有的地理底图中,便于观察对比。所要达到效果如下图(点击放大)所示:

VC 6.0 Release模式下调试代码

有时候需要在Release模式下加断点调试代码,可以采用以下的步骤设置VC 6.0:

1、在Project Settings里选Settings For为All Configurations。

2、在C/C++标签中,Debug info 选 Program Database。

3、在Link 标签中,Category选 Debug,选中Debug info 复选框和Microsoft format。

现在就可以像在Debug版本中那样设置断点进行测试了,但是记住,Release版本由于代码优化,有些变量是观察不到的,所以跟踪变量值的时候可能效果和debug里会有不同,行的运行顺序可能也会不同。

具体原理是什么呢?

首先必须明确的是,什么是Release版程序,什么是Debug版程序

Debug通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序。Release称为发布版本,它往往是进行了各种优化,使得程序在代码大小和运行速度上都是最优的,以便用户很好地使用。

Debug 和 Release 的真正秘密,在于一组编译选项。下面列出了分别针对二者的选项(当然除此之外还有其他一些,如/Fd /Fo,但区别并不重要,通常他们也不会引起 Release 版错误,在此不讨论)

Debug 版本
参数 含义
/MDd /MLd 或 /MTd 使用 Debug runtime library (调试版本的运行时刻函数库)
/Od 关闭优化开关
/D “_DEBUG” 相当于 #define _DEBUG,打开编译调试代码开关 (主要针对assert函数)
/ZI 创建 Edit and continue(编辑继续)数据库,这样在调试过程中如果修改了源代码不需重新编译
/GZ 可以帮助捕获内存错误
/Gm 打开最小化重链接开关, 减少链接时间

Release 版本
参数 含义
/MD /ML 或 /MT 使用发布版本的运行时刻函数库
/O1 或 /O2 优化开关,使程序最小或最快
/D “NDEBUG” 关闭条件编译调试代码开关 (即不编译assert函数)
/GF 合并重复的字符串, 并将字符串常量放到只读内存, 防止被修改

实际上,Debug 和 Release 并没有本质的界限,他们只是一组编译选项的集合,编译器只是按照预定的选项行动。事实上,我们甚至可以修改这些选项,从而得到优化过的调试版本或是带跟踪语句的发布版本。

Oracle 10.2.0.1升级至 10.2.0.4【备忘】

刚开始接触Oracle数据库,边学边记录。最近需要在虚拟机上装一个空的10.2.0.4版本的Oracle数据库以满足以前的一个项目的使用,但手头上只有Oracle 10.2.0.1版本的安装包(官方已经不再提供11g以前的程序安装包了,所以没地方下载),以及10.2.0.4版本的升级包。因此需要先安装Oracle 10.2.0.1,然后再进行升级。

C++调用微软类库操作Excel详细示例

最近需要一个属性数据库导出查询、统计信息到Excel中的功能,之前也没有系统的学习过代码操作Excel,只用过ADO的方式读取写入,现在所需的Excel既然是查询统计报表,就必须有较好的排版格式、柱状图、饼状图等东西,所以还得看一下微软office的类库是怎么用的。

主机流量用完之后

  前天晚上意外发现的自己主机流量竟然用完了,Bandwidth Limit Exceeded几个大黑字让我有些摸不着头脑,博客本来就很简洁,也没放多少体积很大的文件,怎么流量会这么快就耗完了呢?咱又没得罪什么人,应该不会是被人恶意刷的吧?找到柳娅姐说明了情况,她二话不说先给我追加了10G的流量,心里面那真叫一个感激!可还是要找到问题源头啊,否则无论给多少流量都会很快被刷完。

【编程】VC++中递归搜索任意目录下的所有指定文件

在一边学习VC++一边进行开发的过程中遇到了这样的需求:通过程序读出一张光盘中所有的指定扩展名的文件,并且以列表的形式显示在程序界面中。若只是查找某一目录下的指定文件还好处理,直接用CFileFind类就可以,但如果遍历该目录下、甚至整个盘符下所有的文件及文件夹就会受限制了。这里我们可以用递归的思想写一个简单函数来实现。