码迷,mamicode.com
首页 > 其他好文 > 详细

《构建之法》(十三)

时间:2017-09-10 10:09:14      阅读:174      评论:0      收藏:0      [点我收藏+]

标签:文化   重要   nbsp   研究   欺诈   缺陷   个人   事业   技能   

软件工程师的誓言(二)

这里接上一篇,摘写具体的软件工程师的誓言中具体应该遵守的规则。即在面对公众、客户与雇主、产品、判断、管理、职业、同事自身

 

原则1:公众

软件工程师的行为应与公众利益一致。特别地,软件工程师应恰当地做到:

1.1 对自己分内工作负有全部责任

1.2 综合考虑软件工程师,雇主,客户,用户与公众的利益

1.3 软件是安全的,符合规范的,通过适当的测试,不降低生活的质量,不侵犯隐私,不对环境造成伤害;只有当以上条件都能够有充分确认,才认可这个软件。软件的终极效用应该是公益的。

1.4 把任何对用户、公众及与软件和相关文档有联系的外界人员可能造成的危害,告知相关人员或者专家。

1.5 努力合作来解决由软件及其安装、维护、支持和文档 所带来的公众关注的重要问题。

1.6 在所有关系到软件或者相关文件、方法和工具的的声明,尤其是在那些公开声明中,要做到公正并避免欺诈。

1.7 要考虑到由物理缺陷、资源分配、经济劣势和其他一些会降低软件收益的因素所带来的结果。

1.8 鼓励自愿将专业技能用于公益事业,促进公共学科教育的发展。

 

原则2:客户与雇主

软件工程师应以他们的客户和雇主最大利益化的方式做事,与公众利益一致。特别地,软件工程师应该视情况而定按如下原则工作:

2.1. 在他们的能力范围之内提供服务,诚实和坦率地对待他们经验和教育上的任何局限。

2.2. 不故意使用那些获得或保留的非法或者不道德的软件。

2.3. 只在正确地授权后使用客户或雇主的资产,并且在客户或雇主的知识和允许中进行。

2.4. 确保每一个文档的建立基础都是经过检验的,如果需要的话,由授权人士认证。

2.5 在工作中,对任何机密信息要注意保密,这种保密要与公众利益和法律一致。

2.6 当员工觉得项目将要失败,要及时识别、记录、收集证据并向他们的客户或雇主报告,以证明项目失败的原因。这些原因可能是成本太高,侵犯知识产权,抑或是其它问题。

2.7 当员工意识到在软件或相关文档中涉及某些重大的社会关注问题时,要及时发现、记录并向雇主或客户汇报。

2.8 对主要的雇主负责,不接受影响本职工作的任务。

2.9 尽可能保护雇主或客户的利益,除非出于更高的道德考虑,在这种情况下,向雇主或合适的权力机构反映道德问题。

 

原则3产品

软件工程师应当确保他们的产品以及相关的修改达到尽可能高的专业标准。具体来说,软件工程师应当:

3.1. 力求高质量,可接受的成本和合理的计划;弄清出你做出的所有影响较大的权衡,并且确保它们被雇主和客户所接受,并且把你的计划提供给用户和公众来考虑。

3.2. 确保在工作或提出任何项目的时候,设立恰当,可以达成的目标。

3.3. 识别,定义和解决各种与项目相关的道德,经济,文化,法律和环境。

3.4. 确保自身因受过合适教育和训练,以及拥有足够经验,而有资格去做他们工作或提出的项目。

3.5. 确保使用一个合适的方法去做他们工作或者提出的项目。

3.6. 只要条件许可,就应当采取专业标准去做手头的任务,除非有道德或者技术上的正当理由来支持你不这么做。

3.7. 力求完全理解你工作的specification。

3.8. 确保软件的specification完善,满足用户需求,也经过恰当的批准。

3.9. 对于任何你工作或者提出的项目,要对费用,调度,人员,质量和产出进行现实的和量化的评估,而且要给出对你的评估的不确定性的估计。

3.10. 确保对于你在做的项目的程序和文档,要有足够的测试,调试和复审。

3.11. 确保对于你在做的项目,要有足够的文档,包括所有你发现的问题和解决的方法。

3.12. 开发尊重用户隐私的软件和文档。

3.13. 留心只用合乎道德和法律的手段获取的准确数据,而且只按照被授权的方式去使用它们。

3.14. 维护数据的完整性,对于过期和有问题的数据要敏感。

3.15. 对于任何形式的软件维护,要有和开发新软件一样的专业精神。

 

原则4:判断

软件工程师应当完整独立地进行自己的专业判断。具体来说,软件工程师应当:

4.1. 调节所有的技术判断以支撑和维护价值观。

4.2. 只签署并认可这样的文档:要么是自己管理之下的,要么是自己职权范围且已在业内达成共识的。

4.3. 评估任何软件和文档时保持专业的客观性。

4.4. 不参与贿赂、重复收费等不正当的经济行为。

4.5. 把无可避免的利益冲突通知给所有相关群体。

4.6. 拒绝以任何形式(作为成员或提建议者)参加一个任何形式的(私有的,政府的,专业的)和软件相关的组织,如果这个组织或者他的雇员,客户有未公开的潜在利益冲突。

 

原则5:  

软件项目的经理和领导人员应赞成和促进对软件开发和维护合乎道德规范的管理,特别是在适当的情况下软件工程师应当:

5.1  对其从事的项目保证良好的管理,包括提高质量和减少风险等有效手段;

5.2  保证软件工程师在遵循标准之前便知晓它们;

5.3  保证软件工程师知道雇主是如何保护对雇主或其他人保密的口令、文件和信息的有关策略和方法;

5.4  布置工作任务应先考虑其教育和经验有相应的水平,再加上有进一步教育和成长的要求;

5.5  保证对他们从事或建议的项目,做出现实和定量的估算,包括成本、进度、人员、质量和输出,并对估算的不确定性做出评估;

5.6  在雇佣软件工程师时,需实事求是地介绍雇佣条件;

5.7  提供公正和合理的报酬;

5.8  不能不公正地阻止一个人取得可以胜任的岗位;

5.9  保证对那些在软件、过程、研究、写作、或其它知识产权的所有权方面做出贡献的软件工程师,有一个公平的协议;

5.10  应对违反雇主利益或道德观念的指控,提供正规的听证过程;

5.11  不要求软件工程师去做任何与道德规范相违背的事;

5.12  不能处罚对项目表露出道德关切的人;

 

原则6   职业

在与公众利益一致的原则下,软件工程师应当保证其职业的完整和声誉,尤其地,在适当的情况下,软件工程师应当:

6.1  协助发展一个适合执行道德规范的组织环境;

6.2  推进软件工程知识的普及;

6.3  通过适当参与各种专业组织、会议和书籍的出版,来扩占软件工程知识;

6.4  作为一名职业人员,支持其他软件工程师努力遵循本守则;

6.5  不以牺牲职业、客户或雇主利益为代价,谋求自身利益;

6.6  服从所有监管作业的法规,在这种要求与公众利益有不一致时例外;

6.7  要准确叙述自己所做的软件的特性,不仅要避免错误的断言,也要防止那些纯理论的、空洞的、欺骗的、误导的或者有疑问的断言;

6.8  对所从事的软件和相关的文档,负起检测、修正和报告错误的责任;

6.9  保证让客户、雇主和主管人员知道软件工程师对本道德规范的遵守,及其带来的后果;

6.10  避免加入与本道德规范有冲突的业务和组织;

6.11 要认识违反本规范是与成为一名专业工程师不相称的;

6.12  在出现明显违反本规范时,应向有关当事人表达自己的担忧,除非在没有可能、会影响生产或有危险时才可例外;

6.13  当与明显违反道德规范的人无法磋商,或者会影响工作或有危险时,应向有关部门报告;

 

原则7: 同事

软件工程师应当正直地去帮助他们的同事,尤其是:

7.1. 鼓励同事坚持这个准则。

7.2. 在开发过程中帮助同事。

7.3. 对引用别人的工作注明来源,抵制未经允许的引用。

7.4. 代码审查时做到客观、坦诚,并适当地记录。

7.5. 认真对待同事的建议,担心,抱怨。

7.06. 在帮助你的同事时,你应该对有可能产生的安全问题有充足的了解,并有能力控制,例如是遵守规定,保护密码及机密文件等。

7.7. 不能不正当地干涉同事的工作。但是,从老板角度出发,如果前一条与公司或公共利益冲突,软件工程师可以对同事的工作提出置疑。

7.8. 当遇到自己不能胜任的问题时,请教那个领域的专家。

 

原则8: 自身

软件工程师应当在不违反道德准则的情况下,终生学习以提高自身的专业水平:

8.1. 加强各个方面的能力——分析,标准化、设计、开发、维护、测试、写文档、管理项目进程等。

8.2. 提高能力,在合理的时间内,利用合理的花费,去实现安全、可靠、高质量的软件。

8.3. 提高能力,写出精确、可读、有价值的文档。

8.4. 提高对相关文档、软件、开发环境的理解。

8.5. 加强对相关标准、法律的了解。

8.6. 深入理解这份准则,以及如何将其应用到工作中。

8.7. 不因为偏见而对任何人不公。

8.8. 不参与任何与违反些准则有关的活动。

8.9. 坚信一个专业的软件工程师不会违反此准则。

 

《构建之法》(十三)

标签:文化   重要   nbsp   研究   欺诈   缺陷   个人   事业   技能   

原文地址:http://www.cnblogs.com/xxw-ak/p/7494261.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!