- 필수 기능
- 시작하기
- Glossary
- 표준 속성
- Guides
- Agent
- 통합
- 개방형텔레메트리
- 개발자
- Administrator's Guide
- API
- Datadog Mobile App
- CoScreen
- Cloudcraft
- 앱 내
- 서비스 관리
- 인프라스트럭처
- 애플리케이션 성능
- APM
- Continuous Profiler
- 스팬 시각화
- 데이터 스트림 모니터링
- 데이터 작업 모니터링
- 디지털 경험
- 소프트웨어 제공
- 보안
- AI Observability
- 로그 관리
- 관리
ID: ruby-best-practices/no-extend-data-define
Language: Ruby
Severity: Warning
Category: Best Practices
The rule “Do not extend Data.define
” is an important guideline in Ruby programming. Data.define
is a method used to define a data type with specified fields, and it returns an anonymous class. Extending this anonymous class can lead to unpredictable behaviors and complications in your code, making it less maintainable and potentially introducing bugs.
It’s important because extending Data.define
can lead to a lack of clarity about the hierarchy and structure of your classes. In addition, this practice can make the code more difficult to read and understand for other developers, thereby reducing the code’s maintainability.
Good coding practice dictates that you should avoid extending Data.define
. Instead, you can assign the result of Data.define
to a constant, and use this constant where needed in your code. For example, instead of writing class MyClass < Data.define(:field1, :field2)
, you should write MyClass = Data.define(:field1, :field2)
. This way, MyClass
will be a clearly defined data type with the specified fields, and the code will be more readable and maintainable.
class MyClass < Data.define(:field1, :field2)
end
value = Data.define(:first_name, :last_name)
|
|
For more information, please read the Code Security documentation
Identify code vulnerabilities directly in yourVS Code editor
Identify code vulnerabilities directly inJetBrains products