博客
关于我
C#与Java对比学习:数据类型、集合类、栈与队列、迭达、可变参数、枚举
阅读量:420 次
发布时间:2019-03-06

本文共 1709 字,大约阅读时间需要 5 分钟。

数据类型:

  C#:String与StringBuilder

Java:String与StringBuffer

第一个不习惯是string的第一个字母必须大写了。

第二个不习惯是int得写成Integer了,虽然可以定义int i=0,但是对于泛型等用法必须ArrayList<Integer>。

常用集合类比较:

 

C#  :HashTable         List<T>                                                                Dictionary<T,K>  

Java:HashTable         List(包括:ArrayList<T>,LinkedList<T>)             Map<T,K>(包括:HashMap<T,K>,SortedMap<T,K>)

                                   Set(包括:HashSet<T>,   SoredSet<T>)

Set:不能包含重复的元素;

List:可以包含重复的元素。 

 

集合的类还是挺多的,比较的我头差点都大了,最后才找出这种简单的对应关系。 

Stack 和 Queue:

C#  :Stack<T>  Queue<T>

Java:Stack<T>   Queue(包括四个:LinkedBlockingQueue<T>、ArrayBlockingQueue<T>、PriorityBlockingQueue<T>、DelayQueue<T>)

Stack用法基本一致,Queue用法与名称基本上差天与地,下面有详细解答。 

Java Queue方法名称和C#不同:

Java Queue 的相关方法:

add 
 
 
 
 
 
 
 增加一个元索 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 如果队列已满,则抛出一个IIIegaISlabEepeplian异常

remove 
 
 移除并返回队列头部的元素 
 
 
 如果队列为空,则抛出一个NoSuchElementException异常

element  
返回队列头部的元素 
 
 
 
 
 
 
 
 
 
 
 
 如果队列为空,则抛出一个NoSuchElementException异常

offer 
 
 
 
 
 
 添加一个元素并返回true 
 
 
 
 
 
 
如果队列已满,则返回false

poll 
 
 
 
 
 
 
 
 移除并返问队列头部的元素 
 
 
 
如果队列为空,则返回null

peek 
 
 
 
 
 
 返回队列头部的元素 
 
 
 
 
 
 
 
 
 
 
 
 如果队列为空,则返回null

put 
 
 
 
 
 
 
 
 添加一个元素 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 如果队列满,则阻塞

take        移除并返回队列头部的元素     如果队列为空,则阻塞

 

更详细的参考文章链接:http://www.cnblogs.com/end/archive/2012/10/25/2738493.html 

 

迭代语法:

C#  :
foreach(object o in objList){}  实现迭代的接口名称为:
IEnumerable

Java:foreach(object o : objList){}   实现迭代的接口名称为: Iterable

 

可变参数:

 C#  :void Sum(params int[] list){} 以params 为关键字 

 Java:void sum(int ...list){} 以“...“三个点为关键字

 

枚举,Java的enum还能玩出花样:

  C#  :只能enum设置常量数值

  Java:除了和C#一样的设置常量数值,Java仍保留了特殊类的基本功能,让玩家自己玩;而C#而做了特殊限制。

 

C#与Java字符串转枚举及枚举遍历区别:

C#的转换代码:

    
public 
class Test
    {
        
protected 
void Method()
        {
            A a = (A)Enum.Parse(
typeof(A), 
"
b
");//枚举转换
 
    foreach (string enumName in Enum.GetNames(typeof(A)))
            {
//枚举遍历
            }

        }

        public enum A
        {
            b,
            c
        }
    }

 

Java的转换代码:

 
   
public 
class Test
    {
        
protected 
void method()
        {
            A a = A.valueOf("b");
 
    for (A a : A.values())
            {
//枚举遍历
            }
        }
        
public 
enum A
        {
            b,
            c
        }
     }

 

基本上一致,今天看的内容,基本就这么多了,所以就写到这里了,这么点内容,光比较整理,花了好几个小时,真悲催。

 

你可能感兴趣的文章
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>