• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

使用VC开发程序经验谈(二 续)

发布: 2007-7-01 20:40 | 作者: admin | 来源: | 查看: 13次 | 进入软件测试论坛讨论

领测软件测试网

//下面是上面三个类的实现,注意list的用法

//////////////////////////////////////////////////////////////////////

// CMyArc Class

//////////////////////////////////////////////////////////////////////

//////////////////////////////////////////////////////////////////////

// Construction/Destruction

//////////////////////////////////////////////////////////////////////

CMyArc::CMyArc(MYXYZ i_pc, MYXYZ i_ps, MYXYZ i_pe)

{

         m_pc=i_pc;

         m_ps=i_ps;

         m_pe=i_pe;

}

int CMyArc::Draw(long lDevice)

{

         double dR=sqrt((m_ps.x-m_pc.x)*(m_ps.x-m_pc.x)+(m_ps.y-m_pc.y)*(m_ps.y-m_pc.y)+(m_ps.z-m_pc.z)*(m_ps.z-m_pc.z));

         ::Arc((HDC)lDevice,m_pc.x-dR,m_pc.y-dR,m_pc.x+dR,m_pc.y+dR,m_ps.x,m_ps.y,m_pe.x,m_pe.y);

         return 0;

}

//////////////////////////////////////////////////////////////////////

// CMyPolyLn Class

//////////////////////////////////////////////////////////////////////

//////////////////////////////////////////////////////////////////////

// Construction/Destruction

//////////////////////////////////////////////////////////////////////

CMyPolyLn::~CMyPolyLn()

{

         MYPOLYLN::iterator iter;

         for(iter=m_PolyLn.begin();iter!=m_PolyLn.end();iter++)

         {

                   delete (*iter);

         }

         m_PolyLn.clear();

}

 

int CMyPolyLn::AddPoint(MYXYZ *pxyz)

{

         MYXYZ *p=new MYXYZ;

         *p=*pxyz;

         m_PolyLn.insert(m_PolyLn.end(),p);

         return 0;

}

int CMyPolyLn::Draw(long lDevice)

{

         HDC hdc=(HDC)lDevice;

         MYPOLYLN::iterator iter=m_PolyLn.begin();

//该处为了图形的显示更明显,扩大了线的比例,更改了线的位置,正常情况下应该使用注释中的语句

         MoveToEx(hdc,(*iter)->x*100+100,-(*iter)->y*100+200,NULL);

         //MoveToEx(hdc,(*iter)->x,(*iter)->y,NULL);

         for(iter=m_PolyLn.begin();iter!=m_PolyLn.end();iter++)

         {

         //该处为了图形的显示更明显,扩大了线的比例,更改了线的位置,正常情况下应该使用注释中的语句

                  LineTo(hdc,(*iter)->x*100+100,-(*iter)->y*100+200);

                   // LineTo(hdc,(*iter)->x,(*iter)->y);

         }

         return 0;

}

//////////////////////////////////////////////////////////////////////

// CShape Class

//////////////////////////////////////////////////////////////////////

//////////////////////////////////////////////////////////////////////

// Construction/Destruction

//////////////////////////////////////////////////////////////////////

CShape::~CShape()

{

         list<CMyBase*>::iterator iter;

         for(iter=m_List.begin();iter!=m_List.end();iter++)

         {

                   delete (*iter);

         }

         m_List.clear();

}

int CShape::Draw(long lDevice)

{

         list<CMyBase*>::iterator iter;

         for(iter=m_List.begin();iter!=m_List.end();iter++)

         {

                  (*iter)->Draw(lDevice);

         }

         return 0;

}

       至此,几何元素对象类实现完成,可以在主程序中进行测试

void CShapeView::OnDraw(CDC* pDC)

{

         CShapeDoc* pDoc = GetDocument();

         ASSERT_VALID(pDoc);

         {

                  CShape Shape;

                  CMyArc *pArc=new CMyArc(CMyXYZ(100,100,0),CMyXYZ(100,20,0),CMyXYZ(180,100,0));

                  Shape.m_List.insert(Shape.m_List.end(),pArc);

                  CMyPolyLn *pPolyln=new CMyPolyLn;

                  CMyXYZ xyz(1,1,0);

                  pPolyln->AddPoint(&xyz);

                  xyz.x=2;

                  xyz.y=2;

                  pPolyln->AddPoint(&xyz);

                  xyz.x=2;

                  xyz.y=1;

                  pPolyln->AddPoint(&xyz);

                  Shape.m_List.insert(Shape.m_List.end(),pPolyln);

                  Shape.Draw((long)pDC->m_hDC);

         }

}

       先不要急着运行,现在运行的话会出现一些断言的错误,这是由于你在主程序中new出来空间,而在DLL中释放而造成的(CShape的析构函数在DLL中释放内存),解决该问题的方法详细说明如下:

 

用GlobalAlloc()代替new, 用GlobalFree() 代替delete就不会出错了

    其实还有一个办法,就是把dll的Settings的C/C++选项卡的Code Generation的Use Run-time liberary改成Debug Multithreaded DLL,在Release版本中改成Multithreaded DLL,就可以直接使用new和delete了,没问题

    比较规范点的做法一般是DLL分配的内存由DLL释放。

 

       这里采用设置Debug Multithreaded DLL的方法解决


延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网