快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

java代码有哪些问题 看懂java代码

java开发的缺点有哪些?

我认为Java语言的10大问题是:\x0d\x0a1、缺少闭包(closure):我想这个不需要解释了。函数式编程已经存在几十年了,但最近几年,它们获得了越来越多的关注,最主要的原因,是它可以自然地编写并行程序。我部分的同意Joshua Bloch强调在Java中引入闭包的问题需要再想一想(BGGA提议的方式真的很糟),至少闭包的缺失,使得在Java中做任何真正的函数式编程都是不可能的。\x0d\x0a2、缺少一等函数:这个问题与前一个有些关联,但我认为它更糟糕。在Java里,要达到类似效果的唯一方式,是使用著名的、丑陋悲惨的单方法匿名内部类,但这看上去的确是一个拙劣的方法。甚至在C#中,也通过代理机制,提供了一个更好的实现。\x0d\x0a3、原生类型(Primitive types):如果在Java中一切皆对象,那是多么完美啊,但他们偏偏不这样设计。因而,这一点导致了一些问题,比如,不能把一个int放到集合(Collection)里,这个在Java5中通过自动装箱特性得到了解决(下面会提到)。它也造成了传值与传引用上的困扰,原生类型数据是通过值传给方法的(复制一份拷贝,然后传给函数),而真正的对象是通过传递(译注:其实是复制对象地址再传递,因此应该也是传值方式,只是由于函数内部可通过这个对象地址访问对象,因此效果上类似传引用)。\x0d\x0a4、自动装箱(Autoboxing)和自动拆箱(autounboxing):这个特性是为了解决因原生类型的存在所导致的问题,在Java5引入的。它允许静默地转换原生类型到相应的对象,但这常常导致其它的问题。比如Integer可以为null,但int不能,因此这时JVM只能抛出一个难以调试的空指针异常(NullPointerException)。此外,它还可能导致其它奇怪的行为,就像下面的例子,我们就很难理解,变量test为什么是false:\x0d\x0aIntger a = new Integer(1024);\x0d\x0aIntger b = new Integer(1024);\x0d\x0aboolean test = a b;\x0d\x0a5、缺少范型具类化:范型是Java5引入的一个很酷的特征,但是为了保持与旧版本Java的兼容性,导致缺失某些重要的特性,尤其是不能在运行时反省范型的类型。例如,你有一个方法,接受List参数,如果传进来一个List,你却不能知道运行里该范型的确切类型。同理,你也不能创建范型数组。这意味着,尽管下面的代码看起来很自然,但却不编译不了:\x0d\x0aList[] listsOfStrings = new List[3];\x0d\x0a6、不可避免的范型警告:你有发现过自己陷入不可能去掉的关于范型的警告么?如果你像我一样大量使用范型,我打赌你碰到过。事实上,是这个问题的规模化症状,让他们认为需要引入一个特定的注解(@SuppressWarnings("unchecked"))来处理这种情况,我觉得,范型应该可能被设计的更好。\x0d\x0a7、不能传void给方法调用:我得承认,这种给方法传递void的需求,乍一看有些怪异。我喜欢DSL,当我实现自己的DSL库(lambdaj)的一个特定特性时,我不得不需要一个方法声明成这样的签名:void doSomething(Object parameter),这里为这个方法传进来的参数parameter,是另一个方法调用的结果,它唯一的目的,是注册调用(的对象)自身,以可以在以后执行它。让我吃惊的是,即使println方法返回void,看上去也并没有一个好理由,不允许我把代码写成这样,:\x0d\x0adoSomething(System.out.println("test"));\x0d\x0a8、没有原生的代理机制:代理是一种非常有效和应用广泛的模式,但Java提供的代理机制,只针对接口,而不是具体类。这是为什么象cblib这样提供这种机制的库,被如此多的主流框架,如Spring和Hibernate,采用的原因。此外,由于cglib通过运行时创建被代理类的子类来实现的,因此这些种方式有一个众所周知的限制——不能代理final类,比如String。\x0d\x0a9、差劲的Switch...case语句:Java规定,switch...case只能选择int和enum(Java5开始)。这一点如果跟更现代的语言如Scala相比,看起来简直太弱了。\x0d\x0a10、受检查异常(Checked exception):类似原生类型,受检查异常也已经成为Java的一个罪孽之源。它迫使程序员必须做下面两件极其糟糕讨厌的事情中的一个:让你的代码里充斥大量的、糟糕难读的、容易出错的try...catch语句,而这样做的最大意义,只是将捕获的异常,包装成运行时异常,然后再重新抛出;或者是让大量的抛出声明子句污染你的API,让接口缺少灵活性和可扩展性。\x0d\x0a真正的问题是,这里我提到的这几大主要问题,唯一的解决办法,是要做一个痛苦的决择,定义一套新的语言规范,放下当前版本的向后兼容性。我猜他们永远也不会这么做,虽然我相信,如果编写一个能够自动转换旧Java源码的程序,让它们与假设的新版本兼容,并不是很困难。最后,这就是我决定开始寻找一个更好的JVM兼容语言的原因。

西和网站建设公司成都创新互联公司,西和网站设计制作,有大型网站制作公司丰富经验。已为西和成百上千提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的西和做网站的公司定做!

北大青鸟java培训:代码重构过程中会产生哪些常见问题?

相信大家在开发软件和进行软件维护的时候也会发现,有时候我们会针对一些软件的功能进行代码重构来让系统运行更加的稳定。

今天四川java培训就一起来了解一下,在代码重构的过程中都会遇到哪些问题。

1、离线任务和模型的管理问题。

我们做在线服务的都有体会,我们经常容易对线上业务逻辑代码更关注一些,而往往忽视离线代码任务的管理和维护。

但离线代码任务和模型在推荐场景中又至关重要。

因此如何有效维护离线代码和任务,是我们面临的一个问题。

2、特征日志问题。

在推荐系统中,我们常常会遇到特征拼接和特征的『时间穿越』的问题。

所谓特征时间穿越,指的是模型训练时用到了预测时无法获取的『未来信息』,这主要是训练label和特征拼接时时间上不够严谨导致。

如何构建便捷通用的特征日志,减少特征拼接错误和特征穿越,是我们面临的二个问题。

3、服务监控问题。

一个通用的推荐系统应该在基础监控上做到尽可能通用可复用,减少具体业务对于监控的开发量,并方便业务定位问题。

4、离线任务和模型的管理问题。

在包括推荐系统的算法方向中,需要构建大量离线任务支持各种数据计算业务,和模型的定时训练工作。

但实际工作中,我们往往忽略离线任务代码管理的重要性,当时间一长,各种数据和特征的质量往往无法保证。

为了尽可能解决这样的问题,我们从三方面来做,一,将通用推荐系统依赖的离线任务的代码统一到一处管理;二,结合公司离线任务管理平台,将所有任务以通用包的形式进行管理,这样保证所有任务的都是依赖新包;三,建设任务结果的监控体系,将离线任务的产出完整监控起来。

5、特征日志问题。

AndrewNg之前说过:『挖掘特征是困难、费时且需要专业知识的事,应用机器学习其实基本上是在做特征工程。

』我们理想中的推荐系统模型应该是有干净的RawData,方便处理成可学习的Dataset,通过某种算法学习model,来达到预测效果不断优化的目的。

但现实中,我们需要处理各种各样的数据源,有数据库的,有日志的,有离线的,有在线的。

这么多来源的RawData,不可避免的会遇到各种各样的问题,比如特征拼接错误,特征『时间穿越』等等。

这里边反应的一个本质问题是特征处理流程的规范性问题。

那么我们是如何来解决这一点呢,先,我们用在线代替了离线,通过在线落特征日志,而不是RawData,并统一了特征日志Proto,如此就可以统一特征解析脚本。

Java程序员开发存在哪些错误?

什么是Java程序员呢?Java程序员是这几年出现的,他们的着装经常被吐槽,没有人能够get到他的笑点,总是让人感觉到莫名其妙,这就是很多人眼中的程序员。程序员在进行软件开发的时候,会存在一些错误的问题,学会避免是非常关键的。下面电脑培训为大家介绍一下。

1、改一行代码,不会影响其他功能

做任何事情诚意是非常关键的,在不认真的情况下任何事情都是做不好的。如果随意改动代码,在连接数据库的时候会出现很多问题。想要成为一名合格的程序员,对代码的严谨性是非常关键的。

2、不考虑自身问题

在进行软件开发的过程中,存在问题是不可避免的,如何面对和处理问题才是最关键的。如果在遇到问题的时候一直认为是电脑的问题,这样想法想要成为合格的程序员是不可能的。IT培训认为硬件问题是比较少的,不能很好的解决自己的问题想要成功是不可能的。

3、使用临时的方法

临时方法并不是解决问题的最好方法,在进行编程的过程中,由于可能出现的问题比较多,如果使用临时办法,最终可能会演变为永久的办法,这对于程序员来说,北大青鸟认为是非常避讳的解决方法。

4、以后在给代码添加注释

习惯是需要在生活中不断养成的,好的习惯是成功的垫脚石。在进行代码书写的时候也应该有一个好的习惯,如果只会一味地推脱,很难让自己前进。

5、测试过,没有BUG

有的程序员永远不承认自己存在问题,代码存在BUG是很正常的,就算进行测试之后也会出现同样的问题。在程序出现问题的时候不要一味的认为是使用而导致的,北大青鸟云南计算机学院认为,作为程序员,应该解决所有存在的问题。


分享标题:java代码有哪些问题 看懂java代码
文章来源:http://6mz.cn/article/hgopcc.html

其他资讯