`
michael8335
  • 浏览: 188515 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

由一段代码发表一点想法

阅读更多
今天在公司发现了一段很怪异的代码,为此还跟公司员工争执了一下,但由于自身是新员工,我只有无奈的屈服了,心里确实不爽,在这里发表一下自己的看法。先看一下代码,代码已经我已经简化了,只有两个类,一个是action层,另一个是Service层,具体如下:
Action:
package com.yf.test;

import java.util.List;

public class Action {
	public void excute(){
		List list=null;
		list=Service.doSomething();
		if(list.isEmpty()){
			/*
			 *此处省略其他操作
			 */
		}
	}
}

Service
package com.yf.test;

import java.util.ArrayList;
import java.util.List;

public class Service {
	public static List doSomething() {
		List list = new ArrayList();
		if(1==2){
			/*
			 * 此处省略对list的其他操作
			 *  list=.....
			 */			
		}
		return list;
	}
}

当我看到if(list.isEmpty()){时,发现潜在产生空指针异常的可能,然后就给同事说了一下,这里应该先判断List是否为null,然后他让我看Service层,说Service不会返回null,我看了一下,确实不会返回为null,但是关于这段代码,我觉得写的实在太烂,为什么烂,主要有一下几个原因:
1、在Service层,每次调用doSomething方法时,都实例化一个List,虚拟机都会在堆中为这个list开辟内存,这无疑实在浪费内存和虚拟机的,而且这个list只有在if条件成立时,才需要,如果if不成立,虚拟机还得在方法调用结束后,回收这块内存,这难道不是没事找事吗??
2、在Action层,action不对返回的list做非null判断,这也是一种很恶心的做法,首先,根据面向对象的封装性,Service层中的实现对Action而言,应该是不可见的,Action层应该对其返回值的可能情况做判断,即list!=null必须在Action做,如果后续Service层单独抽出,以API提供Jar包的形式,即我们无法知道里面的具体细节,这时,Action层还得做非空判断。因此,本人觉得,这段代码应该做如下重构
Action:
package com.yf.test;

import java.util.List;

public class Action {
	public void excute(){
		List list=null;
		list=Service.doSomething();
		if(list!=null&&list.isEmpty()){
			/*
			 *此处省略其他操作
			 */
		}
	}
}

Service
package com.yf.test;

import java.util.ArrayList;
import java.util.List;

public class Service {
	public static List doSomething() {
		List list=null;
		if(1==2){
			list= new ArrayList();
			/*
			 * 此处省略对list的其他操作
			 *  list=.....
			 */			
		}
		return list;
	}
}

或许并不是每个人都认同我这种做法,不过我个人觉得这样比较合理,软件设计的时候要讲究层次,各层应该干得事情,就应该在所在层做好,而不是有其下层来保证,这种强依赖下层保证是一种很恶心的做法,如果后续下层代码逻辑变更,还得去上层看看对其的影响,这就很无耻了!!!
21
13
分享到:
评论
58 楼 jayming 2012-10-17  
我同意楼主的观点,空指针很多时候并不是错误,我们不应该让程序在没有错误的情况下抛出空指针异常,参考hibernate返回list的方法,@return a result object returned by the action, or <code>null</code>
57 楼 黯然小伙 2012-10-16  
貌似很多讨论。我的想法是:
项目中最好不要返回null(经历过很多血的教训),尤其是对list和map。
我项目中的解决方法是:
public class Service {  
    public static List doSomething() {  
        if(xxx){  
            List list== new ArrayList();  
            /* 
             * 此处省略对list的其他操作 
             *  
             */   
             return list;
        }  
        return Collections.emptyList();  
    }  
}  

仅供参考,个人愚见。
56 楼 奔三的小生 2012-10-16  
返回一个空对象也不应该返回null,不要对内存太较真
55 楼 maimode 2012-10-16  
kidneyball 写道
谈谈返回null值的问题。在2009年,“null”的发明人就发表了一次演讲,说引入null这个概念是他犯下的一个巨大错误,几十年来造成了软件行业超过十亿美元的损失。(http://www.infoq.com/presentations/Null-References-The-Billion-Dollar-Mistake-Tony-Hoare)。因此我个人的倾向是,除非不得已,不要返回null。

以博主的场景为例,如果我在团队里规定,返回容器类型的方法不能返回null。那么对使用者来说,这个方法总共就三种合法情况:返回非空容器,返回空容器,抛出异常。如果发现返回值为null,那就说明是这个方法本身出错了,使用者可以直接反馈给编写者排错。

反之,如果团队里规定,“返回容器类型的方法里可能返回null”,那么对使用者来说,这个方法有以下几种可能情况:
1. 返回非空容器
2. 返回空容器
3. 抛出异常
4. 返回null,其意义相当于空容器
5. 返回null,其意义相当于抛异常
6. 返回null,有特殊的业务含义
7. 编写者没处理好,不小心返回了null(毕竟空指针是最常见的运行期错误,没有之一)。

使用者拿到一个这样的方法,就必须要在4、5、6、7之间做出选择。如果编写者没有写Javadoc,必须要看具体实现才能确认4和5,要加上一定推理才能确认6。无论选4,5,6,都无法排除可能是7。

说的很透彻!其实楼主和他的同事只是奉行的风格不同罢了,没有说那种风格一定好,但是能确定的是,团队保持一致的风格非常重要。
54 楼 greatghoul 2012-10-16  
kidneyball 写道
1. 容器类型的底层方法应该尽量返回空集,避免返回null。从而避免顶层方法做大量的null判断。具体可参考《Effective Java》。

2. 一个以容器为返回类型的方法,返回空集通常是不常见的异常分支,为一个不常见的分支考虑类创建和垃圾回收层面上的性能问题而导致调用者做大量的额外NP判断并不值得。这类优化应该在有profiling数据支持的情况下再做。

3. “具体细节不可见”的问题,写点Javadoc就能解决。调用者需要参考接口文档知道返回值的具体情况,是很正常的事情。后续维护时要保证接口协议不变,也是很正常的事情。

4. 某些团队都会形成共识,只要是返回容器类型的方法就不返回null。只要大家都遵守这个协议,不会出问题而且可以免去大量无谓的NP判断。博主作为一个新人,应该先了解团队中的开发规范,而不是和现有规则较劲。


对,很多流行框架也是这么做的。
53 楼 skzr.org 2012-10-16  
教人家编程会让其痛苦一辈子
52 楼 jinnianshilongnian 2012-10-16  
mfkvfn 写道
jinnianshilongnian 写道
1、在Service层,每次调用doSomething方法时,都实例化一个List,虚拟机都会在堆中为这个list开辟内存,这无疑实在浪费内存和虚拟机的,而且这个list只有在if条件成立时,才需要,如果if不成立,虚拟机还得在方法调用结束后,回收这块内存,这难道不是没事找事吗??

如果服务层 调用 持久层框架(如hibernate) 即使是空 也是返回一个集合的;
                 自己写业务  如果为null  可以返回Collections.EMPTY_LIST(单例 且不可变的) 
建议:不要过早优化 先保证代码可读和可维护


“为空时返回不一个不可变的Collections.EMPTY_LIST单例”这个是不可以的。
一个方法有可能会返回可变的ArrayList有可能会返回不可变的单例,这是不实现的。

比如
    private static final List<String> XXX = new ArrayList<String>(0);

    private List<String> getList(int a) {
        if (a == 1) {
            return new ArrayList<String>();
        } else {
            return XXX;
        }
    }

    private void b() {
        List<String> b = getList(1);
        b.add("abc");
    }

在编译时不会出错。运行时可能会出错。


这些要看自己怎么处理了,基本没有定式;
如查询 可以返回Collections.EMPTY_LIST
如返回的数据需要修改  建议再做一个List保存处理结果 而不是在之前的List中修改
看自己编码习惯了
51 楼 mfkvfn 2012-10-16  
jinnianshilongnian 写道
1、在Service层,每次调用doSomething方法时,都实例化一个List,虚拟机都会在堆中为这个list开辟内存,这无疑实在浪费内存和虚拟机的,而且这个list只有在if条件成立时,才需要,如果if不成立,虚拟机还得在方法调用结束后,回收这块内存,这难道不是没事找事吗??

如果服务层 调用 持久层框架(如hibernate) 即使是空 也是返回一个集合的;
                 自己写业务  如果为null  可以返回Collections.EMPTY_LIST(单例 且不可变的) 
建议:不要过早优化 先保证代码可读和可维护


“为空时返回不一个不可变的Collections.EMPTY_LIST单例”这个是不可以的。
一个方法有可能会返回可变的ArrayList有可能会返回不可变的单例,这是不实现的。

比如
    private static final List<String> XXX = new ArrayList<String>(0);

    private List<String> getList(int a) {
        if (a == 1) {
            return new ArrayList<String>();
        } else {
            return XXX;
        }
    }

    private void b() {
        List<String> b = getList(1);
        b.add("abc");
    }

在编译时不会出错。运行时可能会出错。
50 楼 lianglaiyang 2012-10-16  
michael8335 写道
finallygo 写道
第一点我支持博主的,因为本来定义的接口就是可能多种实现的,虽然有的人说什么团队规范,但是一个团队规范不能保证所有人都认真的执行,其次还增加了一种潜规则在里面,所以,我采用不信任编程,另外第二个,我觉得还是尽量不要返回null

谢谢了,其实我写这个只是表达一下我的想法,同事想看看大家的看法,不过根据大家的评论来看,有两点是明显的,1、上层要做非空判断;2、下层不应该返回null。感谢大家的评论,从中学习不少。

从人与人相处来说,作为一个新人,楼主应该先向你同事公开道歉,以后遇到意见不合时,就要虚心一点。这个是最重要的,不然如果不汲取这次教训,很难混下去
49 楼 weng 2012-10-16  
yawei 写道
你说的是理论上的东西, 而代码呈现的是实际开发中的最好实现。 server层的实现很合理, list先建立就保证了无论条件如何, 总会返回一个list。

action不检查null是因为,在这种模式下, null意味着重大错误, NPE是可以接受的结果。

这种设计逻辑很多地方都能见到,例如搜索引擎。

胡扯
48 楼 alfusen 2012-10-16  
学习了,学习了!
47 楼 在世界的中心呼喚愛 2012-10-15  
ls几位都说的很好。
我赞成你同事的写法,虽然多开销的一个list,但是action可读性变强了。何况你list=null的情况,返回一个null的list并不好,这样造成action都要去判断。
初期写代码尽量可读性好些,这样别人容易看懂,也容易给你一些意见。效率问题可以在后期慢慢调。
46 楼 michael8335 2012-10-15  
finallygo 写道
第一点我支持博主的,因为本来定义的接口就是可能多种实现的,虽然有的人说什么团队规范,但是一个团队规范不能保证所有人都认真的执行,其次还增加了一种潜规则在里面,所以,我采用不信任编程,另外第二个,我觉得还是尽量不要返回null

谢谢了,其实我写这个只是表达一下我的想法,同事想看看大家的看法,不过根据大家的评论来看,有两点是明显的,1、上层要做非空判断;2、下层不应该返回null。感谢大家的评论,从中学习不少。
45 楼 finallygo 2012-10-15  
第一点我支持博主的,因为本来定义的接口就是可能多种实现的,虽然有的人说什么团队规范,但是一个团队规范不能保证所有人都认真的执行,其次还增加了一种潜规则在里面,所以,我采用不信任编程,另外第二个,我觉得还是尽量不要返回null
44 楼 tobylxy 2012-10-15  
收获不少,谢lz和各位讨论!
43 楼 lycccxzt 2012-10-15  
虽不能提什么意见,但在各位的讨论中获得不少收获。
42 楼 formice 2012-10-15  
支持返回非null的集合,这里的问题关注点不在浪费那点内存上,而应该是程序的健壮性,不要太纠结理论,实际的应用应该灵活,不要把自己局限在条条框框上
41 楼 skzr.org 2012-10-15  
这个要顶-|-==============>
kidneyball 写道
谈谈返回null值的问题。在2009年,“null”的发明人就发表了一次演讲,说引入null这个概念是他犯下的一个巨大错误,几十年来造成了软件行业超过十亿美元的损失。(http://www.infoq.com/presentations/Null-References-The-Billion-Dollar-Mistake-Tony-Hoare)。因此我个人的倾向是,除非不得已,不要返回null。

以博主的场景为例,如果我在团队里规定,返回容器类型的方法不能返回null。那么对使用者来说,这个方法总共就三种合法情况:返回非空容器,返回空容器,抛出异常。如果发现返回值为null,那就说明是这个方法本身出错了,使用者可以直接反馈给编写者排错。

反之,如果团队里规定,“返回容器类型的方法里可能返回null”,那么对使用者来说,这个方法有以下几种可能情况:
1. 返回非空容器
2. 返回空容器
3. 抛出异常
4. 返回null,其意义相当于空容器
5. 返回null,其意义相当于抛异常
6. 返回null,有特殊的业务含义
7. 编写者没处理好,不小心返回了null(毕竟空指针是最常见的运行期错误,没有之一)。

使用者拿到一个这样的方法,就必须要在4、5、6、7之间做出选择。如果编写者没有写Javadoc,必须要看具体实现才能确认4和5,要加上一定推理才能确认6。无论选4,5,6,都无法排除可能是7。

40 楼 kidneyball 2012-10-15  
谈谈返回null值的问题。在2009年,“null”的发明人就发表了一次演讲,说引入null这个概念是他犯下的一个巨大错误,几十年来造成了软件行业超过十亿美元的损失。(http://www.infoq.com/presentations/Null-References-The-Billion-Dollar-Mistake-Tony-Hoare)。因此我个人的倾向是,除非不得已,不要返回null。

以博主的场景为例,如果我在团队里规定,返回容器类型的方法不能返回null。那么对使用者来说,这个方法总共就三种合法情况:返回非空容器,返回空容器,抛出异常。如果发现返回值为null,那就说明是这个方法本身出错了,使用者可以直接反馈给编写者排错。

反之,如果团队里规定,“返回容器类型的方法里可能返回null”,那么对使用者来说,这个方法有以下几种可能情况:
1. 返回非空容器
2. 返回空容器
3. 抛出异常
4. 返回null,其意义相当于空容器
5. 返回null,其意义相当于抛异常
6. 返回null,有特殊的业务含义
7. 编写者没处理好,不小心返回了null(毕竟空指针是最常见的运行期错误,没有之一)。

使用者拿到一个这样的方法,就必须要在4、5、6、7之间做出选择。如果编写者没有写Javadoc,必须要看具体实现才能确认4和5,要加上一定推理才能确认6。无论选4,5,6,都无法排除可能是7。
39 楼 lg_asus 2012-10-15  
原来我也是赞同楼主的做法,看样子我要看看effective java了。 thx

相关推荐

    C语言入门经典(第4版)--源代码及课后练习答案

     本书的目标是使你在C语言程序设计方面由一位初学者成为一位称职的程序员。 内容简介  本书是编程语言先驱者Ivor Horton的经典之作,是C语言方面最畅销的图书品种之一。本书集综合性、实用性为一体,是学习C语言...

    项目启动文档2

    IRBL项目要求成员在发现问题时能够即时通报,新想法要经过集体讨论并记录在案,任何变更都需要通知到相关人员,以免产生信息不对称导致的项目延误。此外,为了激励团队士气,IRBL项目还设立了一套奖励机制。当项目...

    二十三种设计模式【PDF版】

    件,一段时间下来,发现不过如此,挺简单好用,但是你真正理解 J2EE 了吗?你在具体案例中的应用是否也是在延伸 J2EE 的思 想? 如果你不能很好的延伸 J2EE 的思想,那你岂非是大炮轰蚊子,认识到 J2EE 不是适合...

    远程debug流程,方便debug

    远程debug流程,方便debug

    基于麻雀生物特性的搜索算法(SSA)的Matlab实现:原理、代码与实战应用,基于圈养麻雀特性的搜索算法(SSA)matlab实现:原理、代码与警觉机制解析,麻雀搜索算法(SSA)的matlab实现

    基于麻雀生物特性的搜索算法(SSA)的Matlab实现:原理、代码与实战应用,基于圈养麻雀特性的搜索算法(SSA)matlab实现:原理、代码与警觉机制解析,麻雀搜索算法(SSA)的matlab实现 原创代码,注释清晰,可直接运行 研究表明,圈养的麻雀存在两种不同类型:发现者和加入者。 发现者在种群中负责寻找食物并为整个麻雀种群提供觅食区域和方向,而加入者则是利用发现者来获取食物。 在生活中我们仔细观察会发现,当群体中有麻雀发现周围有捕食者时,此时群体中一个或多个个体会发出啁啾声,一旦发出这样的声音整个种群就会立即躲避危险,进而飞到其它的安全区域进行觅食。 这样的麻雀被称为警觉者。 麻雀搜索算法就是利用麻雀的这种生物特性进行迭代寻优的优化算法。 本资源包含以下三部分内容: 1.麻雀搜索算法的基本原理(两篇参考文献),非常适合用来学习。 2.麻雀搜索算法的matlab代码,注释详细,结构清晰。 3.五个群智能优化算法常用的测试函数。 ,麻雀搜索算法(SSA); MATLAB实现; 原创代码; 注释清晰; 可直接运行; 生物特性迭代寻优; 发现者与加入者; 警觉者; 参考两篇文献。

    基于java的五子棋游戏设计源码+论文

    基于java的五子棋游戏设计源码+论文

    deepseek-r1使用指南

    deepseek-r1使用指南

    DeepSeek+DeepResearch-让科研像聊天一样简单

    DeepSeek+DeepResearch——让科研像聊天一样简单 (1)DeepSeek如何做数据分析? (2)DeepSeek如何分析文件内容? (3)DeepSeek如何进行数据挖掘? (4)DeepSeek如何进行科学研究? (5)DeepSeek如何写综述? (6)DeepSeek如何进行数据可视化? (7)DeepSeek如何写作润色? (8)DeepSeek如何中英文互译? (9)DeepSeek如何做降重? (10)DeepSeek论文参考文献指令 (11)DeepSeek基础知识。

    基于dlib及opencv的人脸识别.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    基于人工智能的目标检测应用.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    DSP28335通过SPI与AD7606八路信号采集与通信的实践:实时数值与波形展示在上位机界面上,DSP28335与AD7606 SPI通信:采集八路信号并通过SCI上送至上位机实现数据及波形显示

    DSP28335通过SPI与AD7606八路信号采集与通信的实践:实时数值与波形展示在上位机界面上,DSP28335与AD7606 SPI通信:采集八路信号并通过SCI上送至上位机实现数据及波形显示,Dsp28335利用spi与ad7606通信,采集八路信号,通过sci发送到到上位机显示数值和波形 ,DSP28335; SPI; AD7606; 八路信号采集; SCI; 上位机显示; 数值和波形,DSP28335 SPI通讯 AD7606 八路信号采集 SCI发送上位机显示

    搭建mario机器学习测试系统,进行机器学习。.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    marisa-ruby-0.2.4-4.el7.x64-86.rpm.tar.gz

    1、文件内容:marisa-ruby-0.2.4-4.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/marisa-ruby-0.2.4-4.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊

    基于Tent混沌映射的麻雀搜索算法优化:提高全局搜索能力与初始解质量,基于Tent混沌映射的麻雀搜索算法优化:提高全局搜索能力与初始解质量,基于Tent混沌映射的麻雀搜索算法matlab代码: 针对麻

    基于Tent混沌映射的麻雀搜索算法优化:提高全局搜索能力与初始解质量,基于Tent混沌映射的麻雀搜索算法优化:提高全局搜索能力与初始解质量,基于Tent混沌映射的麻雀搜索算法matlab代码: 针对麻雀搜索算法(SSA)在接近全局最优时,种群多样性减少,易陷入局部最优解等问题,提出了一种混沌麻雀搜索优化算法(CSSA)。 通过改进 Tent 混沌序列初始化种群,提高初始解的质量,增强算法的全局搜索能力; ,基于Tent混沌映射的麻雀搜索算法; CSSA(混沌麻雀搜索优化算法); Tent混沌序列初始化种群; 全局搜索能力。,基于Tent混沌映射的CSSA算法:提高麻雀搜索全局搜索能力

    JavaWeb期刊管理系统_课程设计附课设报告.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    上接战略下接绩效的培训规划.pptx

    上接战略下接绩效的培训规划.pptx

    基于S7-300 PLC和Wincc Flexible触摸屏的温室大棚智能控制解决方案:梯形图程序详解、接线与原理图图谱及组态设计,基于S7-300 PLC与Wincc Flexible触摸屏的温室大

    基于S7-300 PLC和Wincc Flexible触摸屏的温室大棚智能控制解决方案:梯形图程序详解、接线与原理图图谱及组态设计,基于S7-300 PLC与Wincc Flexible触摸屏的温室大棚智能控制解决方案:梯形图程序、接线图与组态画面全解析,No.943 基于S7-300 PLC和Wincc Flexible触摸屏温室大棚控制 带解释的梯形图程序,接线图原理图图纸,io分配,组态画面 ,943; S7-300 PLC; Wincc Flexible触摸屏; 温室大棚控制; 梯形图程序; 接线图原理图; IO分配; 组态画面,S7-300 PLC与Wincc Flexible触摸屏联合打造:No.943温室大棚控制系统的设计与实现

    基于ADMM算法的GAMS程序:发电商竞标策略模型及其应用解析,GAMS程序解析:基于ADMM算法的发电商竞标策略优化模型与代码实现,GAMS程序:ADMM算法-基于ADMM法的发电商竞标策略 本程序

    基于ADMM算法的GAMS程序:发电商竞标策略模型及其应用解析,GAMS程序解析:基于ADMM算法的发电商竞标策略优化模型与代码实现,GAMS程序:ADMM算法-基于ADMM法的发电商竞标策略 本程序主要介绍ADMM算法在GAMS中的编写方式,模型基于发电商竞标策略进行编写,基本包含了文章中的模型,但并非完全复现,可作为参考程序自学使用,也可在程序的基础上进行修改使用。 需要的同学可根据以下图片研究是否为自己需要的程序进行。 也可提供ADMM部分程序。 程序包括两个,分别为解决战略投资问题的广义MILP制定的GAMS代码、基于提出的共识- admm算法解决战略投资问题的GAMS代码 ,GAMS程序; ADMM算法; 发电商竞标策略; 模型编写; 广义MILP; 共识-ADMM算法; 战略投资问题; 程序修改。,GAMS程序:ADMM算法在发电商竞标策略中的应用示例

    springboot整合Quartz实现动态配置定时任务.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    重庆市农村信用合作社 农商行数字银行系统建设方案.ppt

    重庆市农村信用合作社 农商行数字银行系统建设方案.ppt

Global site tag (gtag.js) - Google Analytics