시가총액: $2.8337T 0.60%
거래량(24시간): $136.9463B -23.72%
공포와 탐욕 지수:

28 - 두려움

  • 시가총액: $2.8337T 0.60%
  • 거래량(24시간): $136.9463B -23.72%
  • 공포와 탐욕 지수:
  • 시가총액: $2.8337T 0.60%
암호화
주제
암호화
소식
cryptostopics
비디오
최고 암호화

언어 선택

언어 선택

통화 선택

암호화
주제
암호화
소식
cryptostopics
비디오

Solidity의 공개, 비공개, 내부 및 외부 기능의 차이점은 무엇입니까?

Solidity's function visibility specifiers—public, private, internal, and external—control access to functions, impacting security, inheritance, and gas costs in smart contracts.

2025/11/20 22:39

Solidity의 함수 가시성 이해

Ethereum 스마트 계약의 기본 프로그래밍 언어인 Solidity는 기능 가시성 지정자를 통해 엄격한 액세스 제어를 시행합니다. 이러한 지정자는 계약 내부, 파생 계약 또는 외부에서 함수를 호출할 수 있는 사람을 결정합니다. 퍼블릭, 프라이빗, 내부, 외부의 네 가지 유형은 접근성의 범위를 정의하고 계약 논리를 확보하는 데 중요한 역할을 합니다.

공공 기능

1. 공개 기능은 계약 내부, 파생 계약 내부, 트랜잭션이나 호출을 통해 외부적으로 어디에서나 액세스할 수 있습니다.

2. 함수가 공개로 표시되면 Solidity는 상태 변수인 경우 getter 함수를 자동으로 생성하거나 계약 인터페이스를 통해 직접 호출을 허용합니다.

3. 이러한 기능은 계약의 ABI(Application Binary Interface)의 일부가 되어 지갑, dApp 및 기타 스마트 계약에서 호출할 수 있게 됩니다.

4. 공공 기능의 경우 외부 호출 오버헤드 및 데이터 인코딩 요구 사항으로 인해 가스 비용이 더 높을 수 있습니다.

5. 일반적인 사용 사례에는 ERC-20 계약의 토큰 전송 또는 잔액 확인과 같은 사용자 대면 기능이 포함됩니다.

비공개 기능

1. 비공개 기능은 동일한 계약 내에서만 호출할 수 있으며 파생된 계약이나 외부 엔터티에서는 완전히 액세스할 수 없습니다.

2. 노출되거나 재정의되어서는 안 되는 민감한 논리를 캡슐화하는 데 이상적입니다.

3. 비공개 함수는 외부 인터페이스의 일부가 아니므로 ABI에 나타나지 않습니다.

4. 개발자는 공개 또는 내부 작업을 지원하는 내부 유효성 검사, 해싱 또는 정리 루틴에 이를 사용하는 경우가 많습니다.

5. 비공개임에도 불구하고 코드는 여전히 온체인에서 볼 수 있습니다. 개인 정보 보호는 소스 숨김이 아닌 실행 액세스만을 의미합니다.

내부 기능

1. 내부 기능은 정의 계약 및 그로부터 상속된 모든 계약 내에서 액세스할 수 있습니다.

2. 주소 기반 상호 작용을 통해서도 외부 계정이나 관련 없는 계약을 통해 직접 호출할 수 없습니다.

3. 상속 계층은 공개적으로 노출하지 않고 재사용 가능한 논리를 공유하기 위해 내부 기능에 크게 의존합니다.

4. 비공개 기능과 마찬가지로 계약의 외부 ABI에 기여하지 않습니다.

5. 예에는 OpenZeppelin의 SafeMath 라이브러리에 있는 유틸리티 함수나 여러 메서드에 걸쳐 전제 조건을 적용하는 수정자가 포함되어 있습니다.

외부 기능

1. 외부 함수는 계약 외부(다른 계약 또는 EOA(외부 소유 계정))에서만 호출할 수 있습니다.

2. 계약 자체도 this.functionName() 구문을 사용하여 자체 외부 함수를 호출해야 하며, 이로 인해 메시지 호출 오버헤드가 발생합니다.

3. 이 가시성은 기능이 내부적으로 실행되지 않도록 하여 모듈성을 촉진하고 가스 오용을 줄이려는 경우에 유용합니다.

4. 외부 기능은 ABI에 포함되어 있으며 트랜잭션 또는 계약 간 호출을 통해 호출될 수 있습니다.

5. calldata(외부 함수에서 사용)는 내부 호출과 관련된 메모리 복사 비용을 방지하므로 대용량 데이터 입력에 일반적으로 사용됩니다.

자주 묻는 질문

파생 계약에서 비공개 기능을 재정의할 수 있나요? 아니요, 비공개 기능은 파생 계약으로 액세스하거나 재정의할 수 없습니다. virtual 및 override 키워드를 사용하면 내부 및 공용 기능만 재정의할 수 있습니다.

가시성 수정자를 지정하지 않으면 어떻게 되나요? 가시성을 지정하지 않으면 Solidity는 함수에 대해 기본적으로 공개로 설정됩니다. 상태 변수의 경우 기본값은 내부입니다. 보안과 명확성을 이유로 기본값을 사용하는 것은 권장되지 않습니다.

내부 함수 호출과 외부 함수 호출 간에 성능 차이가 있습니까? 예. 내부 호출은 동일한 계약 컨텍스트 내에서 실행되며 최소한의 가스를 사용합니다. 자체 참조되는 경우에도 외부 호출에는 메시지 호출이 필요하므로 스택 격리 및 ABI 인코딩으로 인해 가스 소비가 증가합니다.

외부 함수가 상태 변수를 수정할 수 있나요? 예, 외부 함수는 view 또는 pure와 같은 다른 수정자에 의해 제한되지 않는 한 상태 변수를 수정할 수 있습니다. 스토리지를 변경하는 능력은 가시성이 아닌 논리에 따라 달라집니다.

부인 성명:info@kdj.com

제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!

본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.

관련 지식

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

2026-01-20 22:20:26

EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

2026-01-24 21:00:23

계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

2026-01-21 07:59:57

온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

2026-01-26 08:59:35

스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

2026-01-20 22:20:26

EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?

2026-01-24 21:00:23

계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?

2026-01-21 07:59:57

온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?

2026-01-26 08:59:35

스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

모든 기사 보기

User not found or password invalid

Your input is correct