后台开发:核心技术与应用实践3.1 STL是什么

第3章


常用STL的使用


3.1 STL是什么

当今时代是一个信息时代,科技的发展所带来的便利影响了人们生活中的每个细节,STL就是这个时代组件化大生产的产物。正如其他科技成果一样,C++程序员也应该努力使自己适应并充分利用这个“高科技成果”。

STL是一个标准模板库,是一个高效的C++程序库。接下来将以一个实例程序为例,逐步介绍STL的内容与功能。

假设需要从标准输入(一般是键盘)读入一些整型数据,再对它们排序,然后将结果输出到标准输出设备(一般是显示器屏幕),那程序可以如例3.1所示。

【例3.1】 用原始的方式将一些数据进行排序。

#include<iostream>

#include<stdlib.h>

using namespace
std;

#define max_size
10

// 比较两个数的大小

// 如果比较函数返回大于0,qsort就认为a>b

// 如果比较函数返回等于0,qsort就认为a=b

// 如果比较函数返回小于0,qsort就认为a<b

int cmp(const
void *a,const void *b){

    return *(int *)a-*(int *)b;

}

int main(){

    int arr[max_size];

    int n=0;

    // 从标准输入设备中读入整数,同时累计输入个数,直到输入的是非整型数据为止

    for(;;n++){

        cin>>arr[n];

    }

    qsort(arr,n,sizeof(int),cmp);

    for(int i=0;i<n;i++){

        cout<<arr[i]<<"
";

    }

    return 0;

}

以下是某次运行的结果:

输入:0 9 2 1 5

输出:0 1 2 5 9

例3.1中用了一个可以放10个整数的整型数组,来存放输入的数据,规定从标准输入设备中读入整数,同时累计输入个数,直到输入的是非整型数据为止;还用了C标准库的快速排序quit-sort函数来对输入的整数进行排序,并将排序结果输出到标准输出设备上。

然而,这个程序并不像看起来那么健壮(robust)。如果用户输入的数字数超过max_size所规定的上限,就会出现数组越界问题。为了弥补程序中的这一缺陷,必须采用下述方案中的一种。

(1)采用大容量的静态数据分配。

(2)限定输入的数据个数。

(3)采用动态内存分配。

第一种方案比较简单,所做的只是将max_size改大一点,比如1000或者10?000。但是,严格讲这并不能最终解决问题,隐患仍然存在。此外,分配一个大数组,通常是在浪费空间,因为大多数情况下,数组中的一部分空间并没有被利用。

再来看看第二种方案,通过在第一个for循环中加入一个限定条件,可以使问题得到解决。比如:for (int n = 0; cin >> num[n] && n < max_size; n
++);但是这个方案同样不甚理想,尽管不会使程序崩溃,但失去了灵活性,使用户无法输入更多的数。

看来只有选择第三种方案了,利用指针以及动态内存分配可以妥善解决上述问题,并且使程序具有良好的灵活性。这需要用到new、delete操作符,或者malloc(),realloc()和free()函数,但是为此,程序将牺牲其简洁性,使代码量陡增,代码的处理逻辑也不再像原先看起来那么清晰了。很难保证不会在处理这个问题的时候出错,很多程序的bug往往就是这样产生的。同时,stdlib.h库提供了quit-sort函数,避免了自己实现排序算法的麻烦。总之,需要考虑的问题越来越多。

接下来就将从STL的角度分析并解决这类问题。

时间: 2024-08-17 01:15:05

后台开发:核心技术与应用实践3.1 STL是什么的相关文章

后台开发:核心技术与应用实践

后台开发:核心技术与应用实践 徐晓鑫 著 图书在版编目(CIP)数据 后台开发:核心技术与应用实践 / 徐晓鑫著. -北京:机械工业出版社,2016.8 ISBN 978-7-111-54339-8 I. 后- II. 徐- III. 网络-开发 IV. TP393.092 中国版本图书馆CIP数据核字(2016)第167884号 后台开发:核心技术与应用实践 出版发行:机械工业出版社(北京市西城区百万庄大街22号 邮政编码:100037) 责任编辑:李 艺 责任校对:董纪丽 印 刷: 版 次:

后台开发:核心技术与应用实践导读

后台开发:核心技术与应用实践 徐晓鑫 著 图书在版编目(CIP)数据 后台开发:核心技术与应用实践 / 徐晓鑫著. -北京:机械工业出版社,2016.8 ISBN 978-7-111-54339-8 I. 后- II. 徐- III. 网络-开发 IV. TP393.092 中国版本图书馆CIP数据核字(2016)第167884号 后台开发:核心技术与应用实践 出版发行:机械工业出版社(北京市西城区百万庄大街22号 邮政编码:100037) 责任编辑:李 艺 责任校对:董纪丽 印 刷: 版 次:

Android开发:优化ListView实践解析

 在看了一些vogella的文章之后,发现关于android listview性能优化这一段很有意思,于是实践了一下,经过优化,性能确实提升不少! 先看看优化前和优化后的比较: 优化前的log截图: 开发:优化ListView实践解析-"> 优化后的log截图: 并且,在不停滚动ListView的过程中,优化之前会出现ANR现象,在AVD上特别容易复现: 然后,优化后显得很流畅,附上对于的log截图: 下面附上相关代码分析: ListView中的每一个Item由一个ImageView 和一

android-Android后台开发相关书籍资料

问题描述 Android后台开发相关书籍资料 Android APP后台搭建过程,如何使用开发语言实现,请推荐相关书籍,谢谢. 解决方案 <第一行代码> <疯狂Android讲义> <Android群英传> <Android开发艺术探究> 解决方案二: 后台开发相关书籍Android各层开发推荐书籍及资料(转)Android相关开发资料汇总 解决方案三: http://www.jikexueyuan.com/course/2208.html 解决方案四: 深

mysql-app后台开发,如何做好安全性?

问题描述 app后台开发,如何做好安全性? app后台开发一枚,现在要对整个项目做一些安全性,比如拦截非法请求,sql注入什么的 后台开发技术:spring + mybatis + mysql 求一些思路.麻烦了. 解决方案 比如检查密码的sql语句一定要处理特殊字符? = ' 等等,最后还是要写file.将你所设想到的情况全写下来.后期安全还有问题再添加. 解决方案二: 最好安卓请求时要带上自己的用户信息 解决方案三: 接口的话,多加一些加密处理了,然后在登录的时候带token,再就是服务器的

linux 后台开发-后台开发需要些什么东西

问题描述 后台开发需要些什么东西 我是一名大三的学生,想做后台开发,但是又不知道该从哪方面做起.目前Linux c/c++都学的不错,数据结构也学过,SQL.socket网络通信也学过,TCP/IP协议也有一定了解,然后,下一步不知道该干嘛了,我觉得自己学的这些东西比较基础,都不知道怎么怎么能把它们应用实际.望各位大牛能指点迷津 解决方案 这看你想做哪方面的了.linux服务器开发维护,数据库开发维护,网站后台web开发(javawebphp.net等) 解决方案二: 你所学的仅仅是基础,多看看

Linux 后台开发工作中常用的开源库

后台开发,语言主要是 c 和 c++ , 这里简单罗列一下工作中用的很频繁的那些开源软件 1. OpenSSL openssl OpenSSL 是一个安全套接字层密码库,囊括主要的密码算法.常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用. 下载地址: https://www.openssl.org/source/ 2.TinyXML tinyxml 简单,高效,灵活的一套操作 XML 文件的开源库. 下载地址: http://www.grinninglizar

javascript-App后台开发用哪种语言

问题描述 App后台开发用哪种语言 我想问开发一个APP的后台,想实现的功能有实时聊天,图片,视频的上传和下载等, 用java写好,还是其他的好 解决方案 java.php.python.c++.....很多,建议使用java,轮子多,效率高,也可以用python,简单,效率也不低 解决方案二: 后台有很多选择,如果你熟悉android,那么当然选java,那是你熟悉的语言,如果你熟悉js,可以用node.js,其它的语言还有C# VB PHP Ruby Python Go ... 解决方案三:

ios-iOS APP后台开发技术问题请教

问题描述 iOS APP后台开发技术问题请教 如果要搭建一个IOS应用(假设用户量为几十万)的后台服务器,现在比较靠谱的后台架构是怎样的? (先说说我现在的理解,之前做过一些Android开发的事情,当时后台是写了一个简单的Http服务器(利用Netty实现),然后前端和后台的数据交换采用json实现,至于服务器硬件的配置等等没有过考虑.所以我现在可以认识到的后台,就是HTTP请求+Json返回数据.) 想请教一下各位:从服务器硬件到操作系统再到后台技术框架,有没有一个比较系统.成熟.可靠的模式

Java后台开发精选知识图谱

引言: 学习一个新的技术时,其实不在于跟着某个教程敲出了几行.几百行代码,这样你最多只能知其然而不知其所以然,进步缓慢且深度有限,最重要的是一开始就对整个学习路线有宏观.简洁的认识,确定大的学习方向,这样才能事半功倍. 我们经常会遇到这样的情况: 一开始学习一门新技术的时候,面对着很多很多陌生的名词,无从下手,一度想要放弃. 本文首先会给出关于java后台开发和前端适配的一些建议学习路线,接着简单解释一些应用到的高频技术,帮助大家理解和学习,算是一个入门篇. Java后台开发知识一览 1.后端