Software
edg18Tesis16 de Julio de 2015
3.778 Palabras (16 Páginas)278 Visitas
CHAPTER 1 SOLUTIONS
1.2 1. What is the most important differences between generic software product development and custom software development? What might this mean in practice for users of generic software products?
The essential difference is that in generic software product development, the specification is owned by the product developer. For custom product development, the specification is owned and controlled by the customer. The implications of this are significant – the developer can quickly decide to change the specification in response to some external change (e.g. a competing product) but, when the customer owns the specification, changes have to be negotiated between the customer and the developer and may have contractual implications.
For users of generic products, this means they have no control over the software specification so cannot control the evolution of the product. The developer may decide to include/exclude features and change the user interface. This could have implications for the user’s business processes and add extra training costs when new versions of the system are installed. It also may limit the customer’s flexibility to change their own business processes.
1.6. Explain why there are fundamental ideas of software engineering that apply to all types of software systems.
Because of all software systems have common quality attributes, including availability, modifiability, performance, security and safety, testability and usability, the fundamental software ideas provides common solutions or tactics to support those qualities.
1.5 Based on your own knowledge of some of the application types discussed in the textbook (chapter 1, section 1.1.2), explain, with examples, why different application types require specialized software engineering techniques to support their design and development.
Different application types require the use of different development techniques for a number of reasons:
a) Costs and frequency of change. Some systems (such as embedded systems in consumer devices) are extremely expensive to change; others,must change frequently in response to changing requirements (e.g. business systems). Systems which are very expensive to change need extensive upfront analysis to ensure that the requirements are consistent and extensive validation to ensure that the system meets its specification. This is not cost effective for systems that change very rapidly.
b) The most important ‘non-functional’ requirements. Different systems have different priorities for non-functional requirements. For example, a real-time control system in an aircraft has safety as its principal priority; an interactive game has responsiveness and usability as its priority. The techniques used to achieve safety are not required for interactive gaming; the extensive UI design required for games is not needed in safety-critical control systems.
c) The software lifetime and delivery schedule. Some software systems have a relatively short lifetime (many web-based systems), others have a lifetime of tens of years (large command and control systems). Some systems have to be delivered quickly if they are to be useful. The techniques used to develop short-lifetime, rapid delivery systems (e.g. use of scripting languages, prototyping, etc.) are inappropriate for long-lifetime systems which require techniques that allow for long-term support such as design modelling.
1.3 What are the four important attributes that all professional software should have? Suggest
four other attributes that may sometimes be significant.
important attributes are maintainability, dependability, performance and usability. Other attributes that may be significant could be reusability (can it be reused in other applications), distributability (can it be distributed over a network of processors), portability (can it operate on multiple platforms) and inter-operability (can it work with a wide range of other software systems). Decompositions of the 4 key attributes e.g. dependability decomposes to security, safety, availability, etc.
1.8 Discuss whether professional engineers should be certified in the same way as doctors or
lawyers.
• Advantages
– Competitive since they have been trained according to the standardize training procedure.
– Legal binding from the source of certification can ensure the that the software engineer is trusted.
• Disadvantages
– Certification may not reflect the performance of the software engineer.
– No assurance that certified software engineer will guarantee fool-proofed project.
1.4 Apart from the challenges of heterogeneity, business and social change, and trust and
security, identify other problems and challenges that software engineering is likely to face in
the 21st century (Hint: think about the environment).
l Problems and challenges for software engineering (p13)
• Developing systems for multicultural use
• Developing systems that can be adapted (make suitable) quickly to new business needs (or market requirement)
• Designing systems for outsourced development (maybe Oral)
• Developing systems that are resistant to attack (information security)
• Developing systems that can be adapted and configured by end-users (user can design or assemble what they want)
1.9 For each of the clauses in the ACM/IEEE Code of Ethics shown in Figure 1.3, suggest an
appropriate example that illustrates that clause.
Advantages of certification
l Certification is a signal to employers of some minimum level of competence. (2,3)
l Certification improves the public image of the profession. (1,5)
l Certification generally means establishing and checking educational standards and is therefore a mechanism for ensuring course quality. (3,8)
l Certification implies responsibility in the event of disputes (argue). (4)
l Certifying body is likely to be accepted at a national and international level as ‘speaking for the profession’. (6)
Certification may increase the status of software engineers and attract particularly able people into the profession. (1)
1.10 To help counter terrorism, many countries are planning or have developed computer systems
that track large numbers of their citizens and their actions. Clearly this has privacy
implications. Discuss the ethics of working on the development of this type of system.
CHAPTER 2
2.1. Giving reasons for your answer based on the type of system being developed,
suggest the most appropriate generic software process model which might be
used as a basis for managing the development of the following systems.
•A system to control anti-lock braking in a car.
•A virtual reality system to support software maintenance
•A university accounting system that replaces an existing system
•An interactive system that allows railway passengers to find train times
from terminals installed in stations.
• A system to control anti-locking in a car.
– Spiral model. Since this type of system is a safety-critical system, we need to designed a perfect system with no errors since error may lead to a life-threatening situation
• A virtual reality system to support software maintenance.
– Waterfall model. The requirement of this type of system is rarely change or perhaps fix. Therefore, it is better to develop a waterfall model to swift the progress. (We want to focus on maintaining software not focusing on the virtual system performance and esthetics)
• A university accounting system that replaces an existing system.
– Iterative model. Since the this type of system might be a legacy system, we have to iteratively develop part of the system one by one and integrate it to the existing system concurrently.
• An interactive system that allows railway passengers to find train times from terminals installed in stations.
– Prototype model. User requirements may likely to change and fast delivery is essential to be implemented. Therefore, prototype model can save time of development to focus on essential function first to be later completed.
2.2. Explain why incremental development is the most effective approach for developing business software systems. Why is this model less appropriate for real-time systems engineering?
Business software systems usually complex, software intensive, and frequently being changes when business goals or processes are changed. So incremental development is better.
Real-time systems usually involve many hardware components which are not easy to change and cannot be incremental. Also real-time systems usually safety critical which needed be built based on well planned process.
2.3 Why reuse-based process model is essential to have two separate requirements engineering activities in the process?
To make the reuse software engineering a complete model we need to add two more activities of the software process because if we look at the process stages of reuse engineering it starts at component analysis and thenRequirement modification. So we need to have Requirements before being able to modify it. In other words how can we modify a requirement before establishing a requirements and also same is true for validation because at the end the system is required
...
