ทำความเข้าใจกับปัญหา

กระบวนการพัฒนาซอฟต์แวร์โดยทั่วไปเป็นไปตามขั้นตอนเหล่านี้ -

  • การรวบรวมความต้องการ
  • นิยามปัญหา
  • การออกแบบระบบ
  • Implementation
  • Testing
  • Documentation
  • การฝึกอบรมและการสนับสนุน
  • Maintenance

สองขั้นตอนแรกช่วยทีมในการทำความเข้าใจปัญหาซึ่งเป็นขั้นตอนแรกที่สำคัญที่สุดในการหาทางแก้ไข เรียกบุคคลที่รับผิดชอบในการรวบรวมข้อกำหนดกำหนดปัญหาและออกแบบระบบsystem analyst.

การรวบรวมความต้องการ

โดยปกติแล้วลูกค้าหรือผู้ใช้ไม่สามารถกำหนดปัญหาหรือข้อกำหนดของตนได้อย่างชัดเจน พวกเขามีความคิดที่คลุมเครือว่าต้องการอะไร ดังนั้นนักพัฒนาระบบจึงจำเป็นต้องรวบรวมข้อกำหนดของไคลเอ็นต์เพื่อทำความเข้าใจปัญหาที่ต้องได้รับการแก้ไขหรือสิ่งที่ต้องส่งมอบ การทำความเข้าใจโดยละเอียดเกี่ยวกับปัญหานั้นทำได้โดยการทำความเข้าใจในพื้นที่ธุรกิจที่กำลังพัฒนาโซลูชัน คำถามสำคัญบางประการที่ช่วยในการทำความเข้าใจธุรกิจ ได้แก่ -

  • กำลังทำอะไรอยู่?
  • มีการดำเนินการอย่างไร?
  • ความถี่ของงานคืออะไร?
  • ปริมาณการตัดสินใจหรือธุรกรรมคืออะไร?
  • ปัญหาที่กำลังพบคืออะไร?

เทคนิคบางอย่างที่ช่วยในการรวบรวมข้อมูล ได้แก่ -

  • Interviews
  • Questionnaires
  • การศึกษาเอกสารระบบที่มีอยู่
  • การวิเคราะห์ข้อมูลทางธุรกิจ

นักวิเคราะห์ระบบจำเป็นต้องจัดทำเอกสารข้อกำหนดที่ชัดเจนและรัดกุม แต่ละเอียดถี่ถ้วนเพื่อระบุข้อกำหนดของ SMART ที่เฉพาะเจาะจงวัดผลได้ตกลงตามความเป็นจริงและเป็นไปตามเวลา ความล้มเหลวในการทำเช่นนั้นส่งผลให้ -

  • นิยามปัญหาไม่สมบูรณ์
  • เป้าหมายของโปรแกรมไม่ถูกต้อง
  • ทำงานใหม่เพื่อส่งมอบผลลัพธ์ที่ต้องการให้กับลูกค้า
  • ค่าใช้จ่ายที่เพิ่มขึ้น
  • การจัดส่งล่าช้า

เนื่องจากความลึกของข้อมูลที่ต้องการการรวบรวมความต้องการจึงเรียกอีกอย่างหนึ่งว่า detailed investigation.

การกำหนดปัญหา

หลังจากรวบรวมข้อกำหนดและวิเคราะห์แล้วจะต้องระบุคำชี้แจงปัญหาอย่างชัดเจน การกำหนดปัญหาควรระบุอย่างชัดเจนว่าปัญหาหรือปัญหาใดที่ต้องแก้ไข การมีคำชี้แจงปัญหาที่ชัดเจนเป็นสิ่งจำเป็นเพื่อ -

  • กำหนดขอบเขตโครงการ
  • ให้ทีมมีสมาธิ
  • ติดตามโครงการต่อไป
  • ตรวจสอบว่าได้ผลลัพธ์ที่ต้องการเมื่อสิ้นสุดโครงการ