mport java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.ListIterator;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.TreeMap;
import java.util.TreeSet;
import java.util.concurrent.ConcurrentLinkedQueue;
public class TypeTest {
/**
* ArrayList 优缺点 可以快速访问每个元素,调用get(i)方法来访问下标为i的数组元素。 添加对象速度慢,操作其中对象的速度慢 。
*/
private void arrayListTest() {
ArrayList<String> arrayList = new ArrayList<String>();
// 添加
arrayList.add(String.valueOf(1));
arrayList.add(new Integer(2).toString());
arrayList.add("3");
// 在指定位置插入对象
arrayList.add(0, new String("00"));
for (String str : arrayList) {
System.out.println(str); // 0,1,2,3
}
// 查询
// 返回位置
System.out.println(arrayList.indexOf("1")); // 1
// 返回指定位置的对象
System.out.println(arrayList.get(1)); // 1
// 判断对象是否存在
System.out.println(arrayList.contains("3")); // true
// 修改
System.out.println(arrayList.set(1, "11"));
// 删除
arrayList.remove(0); // remove index
arrayList.remove(String.valueOf(2)); // remove obj
// JDK 1.5 后的遍历方式
for (String str : arrayList) {
System.out.println(str); // 11,3
}
// 原始迭代器
ListIterator<String> listIterator = arrayList.listIterator();
String string = null;
while (listIterator.hasNext()) {
string = (String) listIterator.next();
System.out.println(string);
}
// 转换为数组
// 此方法在多线程同时修改 {@code List} 的情况下可能抛出异常
// String[] l = (String[])arrayList.toArray(new
// String[arrayList.size()]);
// 其它的一些方法
arrayList.size(); // 获取大小
arrayList.clear(); // 清空
arrayList.isEmpty(); // 是否为空
arrayList.subList(0, 1); // 截取
arrayList.lastIndexOf("0"); //返回指定的对象在列表中最后一次出现的位置索引。
arrayList.trimToSize();//将此 ArrayList 实例的容量调整为列表的当前大小。
}
/**
* List 接口的链接列表实现。实现所有可选的列表操作,并且允许所有元素(包括 null)。除了实现 List 接口外,LinkedList
* 类还为在列表的开头及结尾 get、remove 和 insert 元素提供了统一的命名方法。这些操作允许将链接列表用作堆栈、队列或双端队列
* (deque)。 此类实现 Queue 接口,为 add、poll
* 等提供先进先出队列操作。其他堆栈和双端队列操作可以根据标准列表操作方便地进行再次强制转换
* 。虽然它们可能比等效列表操作运行稍快,但是将其包括在这里主要是出于方便考虑。
* 是通过节点直接彼此连接来实现的。每一个节点都包含前一个节点的引用,后一个节点的引用和节点存储的值
* 。当一个新节点插入时,只需要修改其中保持先后关系的节点的引用即可,当删除记录时也一样。
*
* 操作其中对象的速度快 不能随即访问:虽然存在get()方法,但是这个方法是通过遍历接点来定位的所以速度慢。
*
* LinkedList在实现Queue时很有用。
*/
private void linkedListTest() {
// 多个线程同时访问链接的哈希集合时保持同步
/*List<String> list = Collections
.synchronizedList(new LinkedList<String>());*/
LinkedList<String> list = new LinkedList<String>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.addFirst("first");
list.addLast("end");
list.getFirst();
list.getLast();
// 其它方法参考ArrayList
}
/**
* HashSet 主要方法
*/
private void hashSetTest() {
HashSet<String> hashSet = new HashSet<String>();
// 添加数据 注意每次插入的数据是无序的
hashSet.add("a");
hashSet.add("b");
hashSet.add("c");
hashSet.add("d");
// 删除数据
hashSet.remove("a");
// 清空数据
hashSet.clear();
// 查询数据
hashSet.contains("a");
hashSet.size();
hashSet.isEmpty();
for (String str : hashSet) {
System.out.println(str);
}
// 转换为数组
String[] strs = (String[]) hashSet.toArray(new String[0]);
}
/**
* LinkedHashSet
*
* 具有可预知迭代顺序的 Set 接口的哈希表和链接列表实现。 此实现与 HashSet 的不同之外在于,后者维护着一个运行于所有条目的双重链接列表。
* 此链接列表定义了迭代顺序,即按照将元素插入到集合中的顺序(插入顺序)进行迭代。 注意,插入顺序不 受在集合中重新插入的 元素的影响。
*/
private void linkedHashSetTest() {
// 多个线程同时访问链接的哈希集合时保持同步
/*Set<String> s = Collections
.synchronizedSet(new LinkedHashSet<String>());*/
LinkedHashSet<String> s = new LinkedHashSet<String>();
s.add("a");
s.add("b");
s.add("c");
s.add("d");
for (String str : s) {
System.out.println(str); // a,b,c,d
}
}
/**
* TreeSet 此类实现 Set 接口,该接口由 TreeMap 实例支持。 此类保证排序后的 set
* 按照升序排列元素,根据使用的构造方法不同,可能会按照元素 的自然顺序 进行排序(参见 Comparable),或按照在创建 set
* 时所提供的比较器进行 排序。
*
* HashSet是基于Hash算法实现的,其性能通常优于TreeSet,我们通常都应该使用HashSet,在我们需要排序的功能时,
* 我门才使用TreeSet
*/
private void treeSetTest() {
TreeSet<Student> s = new TreeSet<Student>(new Student.compareToStudent());
s.add(new Student(1, "a"));
s.add(new Student(2, "b"));
s.add(new Student(4, "d"));
s.add(new Student(4, "c"));
s.first();
s.last();
//其它tree节点操作参考jdk文档
for (Student stu : s) {
System.out.println(stu);
}
/*
* Student [id=1, name=a] Student [id=2, name=b] Student [id=4, name=c]
* Student [id=4, name=d]
*/
}
/**
* 一个基于链接节点的、无界的、线程安全的队列。此队列按照 FIFO(先进先出)原则对元素进行排序。队列的头部 是队列中时间最长的元素。队列的尾部
* 是队列中时间最短的元素。新的元素插入到队列的尾部,队列检索操作从队列头部获得元素。当许多线程共享访问一个公共 collection
* 时,ConcurrentLinkedQueue 是一个恰当的选择。此队列不允许 null 元素。
*/
private void concurrentLinkedQueueTest() {
ConcurrentLinkedQueue<String> concurrentLinkedQueue = new ConcurrentLinkedQueue<String>();
concurrentLinkedQueue.add("a");
concurrentLinkedQueue.add("b");
concurrentLinkedQueue.add("c");
concurrentLinkedQueue.offer("d"); // 将指定元素插入到此队列的尾部。
concurrentLinkedQueue.peek(); // 检索并移除此队列的头,如果此队列为空,则返回 null。
concurrentLinkedQueue.poll(); // 检索并移除此队列的头,如果此队列为空,则返回 null。
for (String str : concurrentLinkedQueue) {
System.out.println(str);
}
}
/**
* HashMap 基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了不同步和允许使用
* null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。、
* 使用HashMap要求添加的键类明确定义了hashCode()和equals()的实现。
*/
private void hashMapTest() {
HashMap<Integer, Student> map = new HashMap<Integer, Student>();
map.put(1, new Student(1, "a"));
map.put(2, new Student(2, "a"));
map.put(3, new Student(3, "a"));
map.put(4, new Student(4, "a"));
System.out.println(map.containsKey(1));// true
System.out.println(map.containsValue(new Student(4, "a")));// true
System.out.println(map.get(2)); // Student [id=2, name=a]
// 获取所有的 key
Set<Integer> keySet = map.keySet();
for (Integer i : keySet) {
System.out.println(i); // 1,2,3,4
}
// 遍历 Map
Set<Map.Entry<Integer, Student>> entries = map.entrySet();
for (Map.Entry<Integer, Student> entry : entries) {
System.out.println(entry.getKey() + ":" + entry.getValue());
}
// 1:Student [id=1, name=a]
// 2:Student [id=2, name=a]
// 3:Student [id=3, name=a]
// 4:Student [id=4, name=a]
}
/**
* 此类实现一个哈希表,该哈希表将键映射到相应的值。任何非 null 对象都可以用作键或值。 Hashtable 是同步的。
*/
private void hashTableTest() {
Hashtable<String, Integer> numbers = new Hashtable<String, Integer>();
numbers.put("one", new Integer(1));
numbers.put("two", new Integer(2));
numbers.put("three", new Integer(3));
Integer n = (Integer) numbers.get("two");
if (n != null) {
System.out.println("two = " + n);
}
// 其操作方法参考 HashMap
}
/**
* TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果你就应该使用TreeMap
*/
private void treeMapTest() {
TreeMap<String, Integer> numbers = new TreeMap<String, Integer>();
numbers.put("one", new Integer(1));
numbers.put("two", new Integer(2));
numbers.put("three", new Integer(3));
// 其操作方法参考jdk文档
}
/**
* Properties Properties 类表示了一个持久的属性集。Properties
* 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。
*/
private void propertiesTest() {
Properties properties = new Properties();
OutputStream os = null;
try {
os = new FileOutputStream(getClass().getResource("test.properties")
.getFile());
} catch (FileNotFoundException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try {
properties.load(getClass().getResourceAsStream("test.properties"));
properties.getProperty("key");
properties.getProperty("key", "default");
properties.setProperty("new key", "new value");
properties.store(os, "comment");
os.close();
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* @param args
*/
public static void main(String[] args) {
// 测试 ArrayList
// TypeTest.arrayListTest();
// TypeTest.hashSetTest();
// TypeTest.linkedHashSetTest();
new TypeTest().hashMapTest();
}
}
class Student implements Comparable {
private int id;
private String name;
public Student(int id, String name) {
super();
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student [id=" + id + ", name=" + name + "]";
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + id;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Student other = (Student) obj;
if (id != other.id)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
static class compareToStudent implements Comparator // 定义一个内部类来实现比较器
{
public int compare(Object o1, Object o2) {
Student s1 = (Student) o1;
Student s2 = (Student) o2;
int rulst = s1.id > s2.id ? 1 : (s1.id == s2.id ? 0 : -1);
if (rulst == 0) {
rulst = s1.name.compareTo(s2.name);
}
return rulst;
}
}
@Override
public int compareTo(Object o) {
int result;
Student s = (Student) o;
result = id > s.id ? 1 : (id == s.id ? 0 : -1);
if (result == 0) {
result = name.compareTo(s.name);
}
return result;
}
}
相关推荐
Comments Comment Style File Comments Class Comments Function Comments Variable Comments Implementation Comments Punctuation, Spelling and Grammar TODO Comments Deprecation Comments Formatting Line ...
基于的手势识别系统可控制灯的亮_3
untitled2.zip
S7-1500和分布式外围系统ET200MP模块数据
anaconda配置pytorch环境
高校教室管理系统,主要的模块包括查看首页、个人中心、教师管理、学生管理、教室信息管理、教师申请管理、学生申请管理、课时表管理、教师取消预约管理、学生取消预约管理等功能。
半挂汽车列车横向稳定性控制研究:基于模糊PID与制动力矩分配的联合仿真分析在典型工况下的表现,半挂汽车列车在典型工况下的横向稳定性控制研究:基于模糊PID与制动力矩分配的联合仿真分析,半挂汽车列车4自由度6轴整车model,横向稳定性控制,在低附着系数路面,进行典型3个工况,角阶跃,双移线,方向盘转角。 采用算法:模糊PID,制动力矩分配,最优滑移率滑膜控制。 以上基于trucksim和simulink联合仿真,有对应 p-a-p-e-r参考 ,关键词: 1. 半挂汽车列车 2. 4自由度6轴整车model 3. 横向稳定性控制 4. 低附着系数路面 5. 典型工况(角阶跃、双移线、方向盘转角) 6. 模糊PID算法 7. 制动力矩分配 8. 最优滑移率滑膜控制 9. Trucksim和Simulink联合仿真 10. P-A-P-E-R参考; 用分号隔开上述关键词为:半挂汽车列车; 4自由度6轴整车model; 横向稳定性控制; 低附着系数路面; 典型工况; 模糊PID算法; 制动力矩分配; 最优滑移率滑膜控制; Trucksim和Simulink联合仿真; P-A-P-E-R参考
路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法及其改进算法Matlab代码实现,路径规划人工势场法以及改进人工势场法matlab代码,包含了 ,路径规划; 人工势场法; 改进人工势场法; MATLAB代码; 分隔词“;”。,基于Matlab的改进人工势场法路径规划算法研究
本文介绍了范德堡大学深脑刺激器(DBS)项目,该项目旨在开发和临床评估一个系统,以辅助从规划到编程的整个过程。DBS是一种高频刺激治疗,用于治疗运动障碍,如帕金森病。由于目标区域在现有成像技术中可见性差,因此DBS电极的植入和编程过程复杂且耗时。项目涉及使用计算机辅助手术技术,以及一个定制的微定位平台(StarFix),该平台允许在术前进行图像采集和目标规划,提高了手术的精确性和效率。此外,文章还讨论了系统架构和各个模块的功能,以及如何通过中央数据库和网络接口实现信息共享。
三菱FX3U步进电机FB块的应用:模块化程序实现电机换算,提高稳定性和移植性,三菱FX3U步进电机换算FB块:模块化编程实现电机控制的高效性与稳定性提升,三菱FX3U 步进电机算FB块 FB块的使用可以使程序模块化简单化,进而提高了程序的稳定性和可移植性。 此例中使用FB块,可以实现步进电机的算,已知距离求得脉冲数,已知速度可以求得频率。 程序中包含有FB和ST内容;移植方便,在其他程序中可以直接添加已写好的FB块。 ,三菱FX3U;步进电机换算;FB块;程序模块化;稳定性;可移植性;距离与脉冲数换算;速度与频率换算;FB和ST内容;移植方便。,三菱FX3U步进电机换算FB块:程序模块化与高稳定性实现
光伏逆变器TMS320F28335设计方案:Boost升压与单相全桥逆变,PWM与SPWM控制,MPPT恒压跟踪法实现,基于TMS320F28335DSP的光伏逆变器设计方案:Boost升压与单相全桥逆变电路实现及MPPT技术解析,光伏逆变器设计方案TMS320F28335-176资料 PCB 原理图 源代码 1. 本设计DC-DC采用Boost升压,DCAC采用单相全桥逆变电路结构。 2. 以TI公司的浮点数字信号控制器TMS320F28335DSP为控制电路核心,采用规则采样法和DSP片内ePWM模块功能实现PWM和SPWM波。 3. PV最大功率点跟踪(MPPT)采用了恒压跟踪法(CVT法)来实现,并用软件锁相环进行系统的同频、同相控制,控制灵活简单。 4.资料包含: 原理图,PCB(Protel或者AD打开),源程序代码(CCS打开),BOM清单,参考资料 ,核心关键词:TMS320F28335-176; 光伏逆变器; 升压; 逆变电路; 数字信号控制器; 规则采样法; ePWM模块; PWM; SPWM波; MPPT; 恒压跟踪法; 原理图; PCB; 源程序代码; BOM
centos9内核安装包
昆仑通态触摸屏与两台台达VFD-M变频器通讯实现:频率设定、启停控制与状态指示功能接线及设置说明,昆仑通态TPC7062KD触摸屏与两台台达VFD-M变频器通讯程序:实现频率设定、启停控制与状态指示,昆仑通态MCGS与2台台达VFD-M变频器通讯程序实现昆仑通态触摸屏与2台台达VFD-M变频器通讯,程序稳定可靠 器件:昆仑通态TPC7062KD触摸屏,2台台达VFD-M变频器,附送接线说明和设置说明 功能:实现频率设定,启停控制,实际频率读取等,状态指示 ,昆仑通态MCGS; 台达VFD-M变频器; 通讯程序; 稳定可靠; 频率设定; 启停控制; 实际频率读取; 状态指示; 接线说明; 设置说明,昆仑通态MCGS与台达VFD-M变频器通讯程序:稳定可靠,双机控制全实现
研控步进电机驱动器方案验证通过,核心技术成熟可生产,咨询优惠价格!硬件原理图与PCB源代码全包括。,研控步进电机驱动器方案验证通过,核心技术掌握,生产准备,咨询实际价格,包含硬件原理图及PCB源代码。,研控步进电机驱动器方案 验证可用,可以生产,欢迎咨询实际价格,快速掌握核心技术。 包括硬件原理图 PCB源代码 ,研控步进电机驱动器方案; 验证可用; 可生产; 核心技术; 硬件原理图; PCB源代码,研控步进电机驱动器方案验证通过,现可生产供应,快速掌握核心技术,附硬件原理图及PCB源代码。
高质量的OPCClient_UA源码分享:基于C#的OPC客户端开发源码集(测试稳定、多行业应用实例、VS编辑器支持),高质量OPC客户端源码解析:OPCClient_UA C#开发,适用于VS2019及多行业现场应用源码分享,OPCClient_UA源码OPC客户端源码(c#开发) 另外有opcserver,opcclient的da,ua版本的见其他链接。 本项目为VS2019开发,可用VS其他版本的编辑器打开项目。 已应用到多个行业的几百个应用现场,长时间运行稳定,可靠。 本项目中提供测试OPCClient的软件开发源码,有详细的注释,二次开发清晰明了。 ,OPCClient_UA; OPC客户端源码; C#开发; VS2019项目; 稳定可靠; 详细注释; 二次开发,OPC客户端源码:稳定可靠的C#开发实现,含详细注释支持二次开发
毕业设计
三菱FX3U六轴标准程序:六轴控制特色及转盘多工位流水作业功能实现,三菱FX3U六轴标准程序:实现3轴本体控制与3个1PG定位模块,轴点动控制、回零控制及定位功能,结合气缸与DD马达控制转盘的多工位流水作业模式,三菱FX3U六轴标准程序,程序包含本体3轴控制,扩展3个1PG定位模块,一共六轴。 程序有轴点动控制,回零控制,相对定位,绝对定位。 另有气缸数个,一个大是DD马达控制的转盘,整个是转盘多工位流水作业方式 ,三菱FX3U;六轴控制;轴点动控制;回零控制;定位模块;DD马达转盘;流水作业方式,三菱FX3U六轴程序控制:转盘流水作业的机械多轴系统
在 GEE(Google Earth Engine)中,XEE 包是一个用于处理和分析地理空间数据的工具。以下是对 GEE 中 XEE 包的具体介绍: 主要特性 地理数据处理:提供强大的函数和工具,用于处理遥感影像和其他地理空间数据。 高效计算:利用云计算能力,支持大规模数据集的快速处理。 可视化:内置可视化工具,方便用户查看和分析数据。 集成性:可以与其他 GEE API 和工具无缝集成,支持多种数据源。 适用场景 环境监测:用于监测森林砍伐、城市扩展、水体变化等环境问题。 农业分析:分析作物生长、土地利用变化等农业相关数据。 气候研究:研究气候变化对生态系统和人类活动的影响。
基于博途V16的邮件分拣机控制系统设计与实现:西门子S7-1200PLC与TP700触摸屏程序化及其仿真视频与CAD接线控制要求详解。,邮件分拣机自动化系统设计与实现:基于西门子S7-1200PLC与TP700触摸屏的博途V16程序,包含仿真视频、CAD接线及控制要求详解。,邮件分拣机控制系统西门子S7-1200PLC和TP700触摸屏程序博途V16,带仿真视频CAD接线和控制要求 ,邮件分拣; 控制系统; 西门子S7-1200PLC; TP700触摸屏程序; 博途V16; 仿真视频; CAD接线; 控制要求,邮件分拣机控制系统:S7-1200PLC与TP700触摸屏程序博途V16集成仿真视频CAD控制要求