博客
关于我
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
        }
     }

 

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

 

你可能感兴趣的文章
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
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
查看>>