首页 > 其他分享 >迭代器模式

迭代器模式

时间:2022-12-26 10:58:51浏览次数:34  
标签:infile name 迭代 模式 public Student id String

Java

//Student.java
package shiyan18;

public class Student{
    private String id;
    private String name;
    private String age;
    public String getAge() {
        return age;
    }
    public void setAge(String age) {
        this.age = age;
    }
    public Student(){}
    public Student(String id,String name,String age){
        this.id = id;
        this.name = name;
        this.age = age;
    }
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String toString() {
        return "学号=" + id + ", 名字=" + name + ", 年龄=" + age;
    }

    public static Student fromString(String s){
        String[] split = s.split(";");
        if(split.length==3){
            return new Student(split[0],split[1],split[2]);
        }else{
            throw new RuntimeException("不能从字符串‘"+s+"’解析出"+Student.class+"类型的对象!");
        }
    }
}

//Iterators.java
package shiyan18;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.ListIterator;


public class Iterators {

    public static void main(String[] args) {
        InputStream is = Iterators.class.getClassLoader().getResourceAsStream("shiyan18/Student.txt");
        List<Student> list = getStudents(is);

        System.err.println("学号从小到大:");
        Iterator<Student> iterator = list.iterator();
        while(iterator.hasNext()){
            Student student = iterator.next();
            System.out.println(student);
        }
        System.err.println("学号从大到小:");
        ListIterator<Student> li=list.listIterator();
        for(li=list.listIterator();li.hasNext();) {
            li.next();
        }
        for(;li.hasPrevious();) {
            Student student = li.previous();
            System.out.println(student);
        }
    }

    private static List<Student> getStudents(InputStream is){
        List<Student> list = new LinkedList<>();
        BufferedReader reader = new BufferedReader(new InputStreamReader(is));
        String temp = null;
        try {
            while((temp=reader.readLine())!=null){
                Student student = Student.fromString(temp);
                list.add(student);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return list;
    }
}




c++


#include <string>
#include <vector>
#include <iostream>
#include <fstream>
using namespace std;
struct student
{
    string id;
    string name;
};
void LoadStudent(vector<student>&);
int main()
{
    vector<student> v,v1;
    LoadStudent(v);
    LoadStudent(v1);
    cout<<"学号从小到大:"<<endl;
    for (vector<student>::iterator iter = v.begin(); iter != v.end(); ++iter)
    {
        cout << "学号:" << iter->id << "  姓名:" << iter->name << endl;
    }
    cout<<"***********************"<<endl;
    cout<<"学号从大到小:"<<endl;
    for (vector<student>::reverse_iterator iter1 = v.rbegin(); iter1 != v.rend(); ++iter1)
    {
        cout << "学号:" << iter1->id << "  姓名:" << iter1->name << endl;
    }
    return 0;
}
void LoadStudent(vector<student>& v)
{
    ifstream infile;
    infile.open("E:\\student.txt");
    student s;
    if(!infile)     //判断是否存在ifstream infile
    {
        cout<<"读入文件不存在"<<endl;
    }
    if (infile.is_open())   //判断文件流是否处于打开状态
    {
        while (infile.good()&&!infile.eof())
        {
            infile>>s.id>>s.name;
            v.push_back(s);    //将数据读入到data_vector
        }
    }
    infile.close();
}

标签:infile,name,迭代,模式,public,Student,id,String
From: https://www.cnblogs.com/lion999heart/p/17005201.html

相关文章

  • 备忘录模式
    java//Caretaker.javapackageshiyan20;publicclassCaretaker{   privateMemento[]array=null;   privateintindex;   privateMementomemento;  ......
  • 原型模式
    概述《设计模式》一书中对“原型模式”的意图描述如下:用原型实例指定创建对象的种类,并通过拷贝对象的原型创建新的对象貌似有点难懂,概括性地讲就是实现对不同类型对......
  • UML设计模式符号答疑
    在UML类图中,常见的有以下几种关系:泛化(Generalization),  实现(Realization),关联(Association),聚合(Aggregation),组合(Composition),依赖(Dependency) 1.泛化(Generalization)......
  • MongoDB - 模式设计
    注意事项模式设计,即在文档中表示数据的方式,对于数据表示来说时非常关键的。为MongoDB做模式设计时,在性能、可伸缩性和简单性方面是重中之重,也需要考虑一些特别的注意事......
  • 分布式事务方案 - SAGA模式
    本文目的是讲清楚SAGA这种分布式事务解决方案的实现思路,不包括具体实现代码,具体实现推荐使用阿里的Seata框架。内容包括:分布式事务问题描述SAGA-Choreography策......
  • 精通visual c++指纹模式识别系统算法及实现
    通过学习,掌握以下几个问题:1、核心算法,并且向GVF衍生;2、核心库封装的方法2016年11月16日06:52:51昨日实现了梯度场和频率场的计算。最大的感觉就是建立基础代码库的重要性。......
  • 【模式识别】判别函数和感知机算法
    给定两个类别的一共8个样本,通过感知机算法求解判别函数defbi_perception():X1=np.array([[0,0,0],[1,0,0],[1,0,1],......
  • CPU的实模式
    实模式是指CPU的寻址方式,寄存器大小,指令用法等,是用来反应CPU在该环境下如何工作的概念。CPU的工作原理:CPU大体分为三个部分,控制、运算、存储单元。控制单元是CPU的控制中......
  • 1个月连载30个设计模式真实案例,挑战年薪60W不是梦
    本文所有内容均节选自《设计模式就该这样学》本文自2021年10月29日起持续连载,请大家持续关注....序言DesignPatterns:ElementsofReusableObject-OrientedSoft......
  • 设计模式面试题(总结最全面的面试题!!!)
    Java面试总结汇总,整理了包括Java重点知识,以及常用开源框架,欢迎大家阅读。文章可能有错误的地方,因为个人知识有限,欢迎各位大佬指出!文章持续更新中......ID标题地址......