当前位置: 首页 > news >正文

网站索引怎么做网站的开发是使用什么技术

网站索引怎么做,网站的开发是使用什么技术,免费设计室内装修软件,网站备案地址0.目录 1.创建异常对象时的空指针问题 2.LinkList 中的数据元素删除 3.LinkList 中遍历操作与删除操作的混合使用 4.StaticLinkList 中数据元素删除时的效率问题 5.StaticLinkList 是否需要提供析构函数#xff1f; 6.StLib 是否有必要增加多维数组类#xff1f; 1.创建异常对…0.目录 1.创建异常对象时的空指针问题 2.LinkList 中的数据元素删除 3.LinkList 中遍历操作与删除操作的混合使用 4.StaticLinkList 中数据元素删除时的效率问题 5.StaticLinkList 是否需要提供析构函数 6.StLib 是否有必要增加多维数组类 1.创建异常对象时的空指针问题 ISSUE 1——创建异常对象时的空指针问题 改进Exception.cpp 在init函数中改进strdup的赋值方法 void Exception::init(const char* message, const char* file, int line) {/* message指向的字符串有可能在栈上有可能在堆空间还有可能在全局数据区* strdup()将字符串复制一份到堆空间中* file发生异常的文件名* line发生异常的行号* m_location的长度加2一个给:一个给\0*/m_message (message ? strdup(message) : NULL);if( file ! NULL ){char sl[16] {0};itoa(line, sl, 10);m_location static_castchar*(malloc(strlen(file) strlen(sl) 2));if( m_location ! NULL ){m_location strcpy(m_location, file);m_location strcat(m_location, :);m_location strcat(m_location, sl);}}else{m_location NULL;} } 2.LinkList 中的数据元素删除 ISSUE 2——LinkList 中的数据元素删除 单链表的实现没有考虑异常安全性 改进LinkList.h中的remove函数和clear函数 bool remove(int i){bool ret ((0 i) (i m_length));if( ret ){Node* current position(i);Node* toDel current-next;current-next toDel-next;m_length--;destroy(toDel);}return ret;}void clear(){while ( m_header.next ){Node* toDel m_header.next;m_header.next toDel-next;m_length--;destroy(toDel);}} 3.LinkList 中遍历操作与删除操作的混合使用 ISSUE 3——LinkList 中遍历操作与删除操作的混合使用 混合使用导致了m_current指向了已经被删除的结点于是程序出错。 改进LinkList.h中的remove函数 bool remove(int i){bool ret ((0 i) (i m_length));if( ret ){Node* current position(i);Node* toDel current-next;if( m_current toDel ){m_current toDel-next;}current-next toDel-next;m_length--;destroy(toDel);}return ret;} main.cpp测试 #include iostream #include LinkList.husing namespace std; using namespace StLib;int main() {LinkListint list;for(int i0; i5; i){list.insert(i);}for(list.move(0); !list.end(); list.next()){if( list.current() 3 ){list.remove(list.find(list.current()));cout list.current() endl;}}for(int i0; ilist.length(); i){cout list.get(i) endl;}return 0; } 运行结果为 4 0 1 2 4 4.StaticLinkList 中数据元素删除时的效率问题 ISSUE 4——StaticLinkList 中数据元素删除时的效率问题 改进LinkList.h中的destroy函数 void destroy(Node* pn){SNode* space reinterpret_castSNode*(m_space);SNode* psn dynamic_castSNode*(pn);for(int i0; iN; i){if( psn (space i) ){m_used[i] 0;psn-~SNode();break;}}} main.cpp测试 #include iostream #include StaticLinkList.husing namespace std; using namespace StLib;int main() {StaticLinkListint, 10 list;for(int i0; i5; i){list.insert(i);}list.remove(3);for(int i0; ilist.length(); i){cout list.get(i) endl;}return 0; } 运行结果为 0 1 2 4 5.StaticLinkList 是否需要提供析构函数 ISSUE 5——StaticLinkList 是否需要提供析构函数 构造函数与析构函数不会发生多态于是调用的是父类的析构函数 改进StaticLinkList.h 在子类StaticLinkList中实现析构函数 ~StaticLinkList(){this-clear();} 6.StLib 是否有必要增加多维数组类 ISSUE 6——StLib 是否有必要增加多维数组类多维数组的本质数组的数组 不需要定义多维数组 使用DynamicArray创建多维数组 #include iostream #include DynamicArray.husing namespace std; using namespace StLib;int main() {DynamicArray DynamicArrayint d;d.resize(3);for(int i0; id.length(); i){d[i].resize(i 1);}for(int i0; id.length(); i){for(int j0; jd[i].length(); j){d[i][j] i * j;}}for(int i0; id.length(); i){for(int j0; jd[i].length(); j){cout d[i][j] ;}cout endl;}return 0; } 运行结果为 0 0 1 0 2 4 实践经验 是软件就有bug因此需要不停的迭代升级解决问题。库是一种特殊的软件产品也会存在各种bug也需要迭代升级解决问题。转载于:https://www.cnblogs.com/PyLearn/p/10123468.html
http://www.pierceye.com/news/244853/

相关文章:

  • 产看网站权重运维难还是开发难
  • 芜湖中凡网站建设公司中国建设工程招投网站
  • 手机网站开发+图库类13岁开网络科技公司
  • 网站上的产品板块广州展厅设计公司有哪些
  • 网站建设源代码交付网站系统制作教程视频教程
  • 做网站刷赞qq怎么赚钱网站特效js代码
  • 电子商务网站开发进什么科目网络推广怎么学
  • 网站做百度推广要多少钱电商网站制作
  • 交互设计网站推荐网上推广公司
  • 网站建设数据库搭建网站开发外包维护合同
  • 大网站怎样选域名ui设计的就业前景
  • 青岛网站推广外包推广平台怎么做
  • 陇南建设网站网站建设大作业选题
  • 外包做的网站 需要要源代码吗福建省法冶建设知识有奖网站
  • 设计网站价格表dns解析失败登录不了网站
  • 代理网址网站与做机器人有关的网站
  • 优惠卷网站怎么做推广歌手网站建设
  • 网站服务器开发西安app软件开发公司
  • 化妆品产品的自建网站哟哪些怎么做提升网站转化率
  • 上海餐饮网站建设百度本地推广
  • 全返网站建设做pc端网站信息
  • 做团购网站需要什么网站建设与管理好处
  • 厦门seo优泰安网站seo推广
  • 做网站如何盈利建站优化信息推广
  • 大气的网站首页网络推广公司优化客
  • 网站建设要经历哪些步骤电商仓储代发招商合作
  • 网站开发如何搭建框架潍坊网站建设公司
  • 免费网页制作网站建设2015年做啥网站致富
  • 个人网站制作基本步骤江阴网站的建设
  • 英文网站名需要斜体吗宁波seo外包费用