How would you measure code “quality” across a large project

前端 未结 5 762
夕颜
夕颜 2021-02-04 15:20

I\'m working on a quite large project, a few years in the making, at a pretty large company, and I\'m taking on the task of driving toward better overall code quality.

I

相关标签:
5条回答
  • 2021-02-04 15:30

    Maybe you'll find interesting, or insightful, this analysis: A Tale of Four Kernels
    Edit: schema, and the corresponding queries

    0 讨论(0)
  • 2021-02-04 15:39

    If your taking on the task of driving toward better overall code quality. You might take a look at:

    • How many open issues do you currently have and how long do they take to resolve?
    • What process to you have in place to gather requirements?
    • Does your staff follow best practices?
    • Do you have sop's defined to describing your companies programming methodology.

    When you have a number of developers involved in a large project everyone has their way of programming. Each style of programming solve the problem but some answers may be less efficient than others.

    How do you utlize you staff when attacking a new feature or fixing the exist code. Having developers work in teams following programming sop's forces everyone to be a better code.

    When your people code more efficiently following rule you development time should get quicker.

    You can get all the metrics you want but I say first you have to see how things are being done:

    What are you development practices?

    Without know how things are currently being done you can get all the metrics you want but you'll never see any improvemenet.

    0 讨论(0)
  • 2021-02-04 15:49

    Amount of software cloning/duplicate code, less is obviously better. (Link discusses clones and various techniques to detect/measure them.)

    0 讨论(0)
  • 2021-02-04 15:50

    You should organize your work around the six major software quality characteristics: functionality, reliability, usability, efficiency, maintainability, and portability. I've put a diagram online that describes these characteristics. Then, for each characteristic decide the most important metrics you want and are able to track. For example, some metrics, like those of Chidamber and Kemerer are suitable for object-oriented software, others, like cyclomatic complexity are more general-purpose.

    0 讨论(0)
  • 2021-02-04 15:51

    Cyclomatic complexity is a decent "quality" metric. I'm sure developers could find a way to "game" it if it were the only metric, though! :)

    And then there's the C.R.A.P. metric...

    P.S. NDepend has about ten billion metrics, so that might be worth looking at. See also CodeMetrics for Reflector.

    D'oh! I just noticed that you already mentioned NDepend.

    Number of reported bugs would be interesting to track, too...

    0 讨论(0)
提交回复
热议问题