-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
Solidity에서 호출, 위임 호출, 정적 호출의 차이점은 무엇입니까?
Understanding `call`, `delegatecall`, and `staticcall` is crucial for secure Solidity development, as each alters execution context, state access, and security risks differently.
2025/11/14 18:59
호출, 위임 호출, 정적 호출 간의 차이점을 이해하는 것은 Solidity의 안전하고 효율적인 스마트 계약 개발에 필수적입니다. 이러한 하위 수준 기능은 다른 계약 또는 외부 계정과의 상호 작용을 허용하지만 컨텍스트, 상태 수정 및 실행 환경 측면에서 다르게 작동합니다.
부르다
1. 호출 함수는 지정된 양의 Ether를 전달하고 호출된 계약의 컨텍스트에서 코드를 실행하는 동안 다른 계약의 기능을 호출합니다.
- 이는 호출 수신자의 저장소, 코드 및 잔액을 사용합니다. 즉, 모든 상태 변경이 대상 계약 범위 내에서 발생함을 의미합니다.
- 이 방법은 컴파일 타임에 ABI를 알 수 없는 외부 계약과 상호 작용할 때 일반적으로 사용됩니다.
- 호출이 선택적 반환 바이트와 함께 성공 또는 실패를 나타내는 부울을 반환하므로 개발자는 반환 데이터를 신중하게 처리해야 합니다.
- 적절한 확인-효과-상호작용 패턴을 따르지 않으면 오용으로 인해 재진입 취약점이 발생할 수 있습니다.
대리인 호출
1. Delegatecall은 다른 계약의 코드를 실행하지만 호출자의 저장소, 컨텍스트 및 균형을 유지합니다.
- 이는 로직이 데이터와 분리되어 업그레이드 가능한 계약을 가능하게 하는 프록시 패턴에 자주 사용됩니다.
- 상태 수정은 호출 계약의 저장소에 영향을 미치므로 프록시와 구현 간에 저장소 레이아웃을 정렬할 때 극도의 주의가 필요합니다.
- call 과 달리 추가 메커니즘을 통해 명시적으로 전송되지 않는 한 Delegatecall 중에 Ether가 전송되지 않습니다.
- 보안 위험에는 프록시의 소유권이나 잔액과 같은 중요한 변수를 변경하는 악의적인 구현 계약이 포함됩니다.
정적 호출
1. staticcall 은 블록체인의 상태를 수정하지 않는 기능을 호출하도록 설계되었습니다.
- 스토리지에 쓰거나, 이벤트를 내보내거나, 상태를 변경하는 작업을 수행하려고 하면 호출이 되돌려집니다.
- 이 기능은 의도하지 않은 부작용의 위험 없이 외부 계약에서 데이터를 안전하게 읽는 데 유용합니다.
- call 과 마찬가지로 대상 계약의 코드 내에서 작동하지만 실행 시 읽기 전용 모드를 적용합니다.
- 주요 사용 사례에는 토큰 잔액 쿼리, 허용량 확인 또는 제3자 계약에서 변경할 수 없는 값 검색이 포함됩니다.
일반적인 질문
델리게이트 콜이 스토리지 레이아웃이 일치하지 않는 계약을 대상으로 하는 경우 어떻게 됩니까? 호출 계약의 저장소 슬롯이 호출된 계약의 논리에서 예상하는 것과 일치하지 않으면 변수를 잘못 덮어쓸 수 있습니다. 예를 들어, 한 슬롯에 저장된 주소는 uint256으로 해석되어 데이터가 손상되거나 무단 액세스가 발생할 수 있습니다.
지불 가능한 함수와 상호 작용하는 데 staticcall을 사용할 수 있습니까? 예, staticcall은 실제로 상태를 수정하지 않는 한 지불 가능한 함수를 대상으로 할 수 있습니다. 그러나 값 전송은 본질적으로 상태 변경을 포함하고 호출이 실패할 수 있기 때문에 staticcall을 통해 Ether를 보내는 것은 중복됩니다.
특정 시나리오에서 호출이 정적 호출보다 더 위험한 것으로 간주되는 이유는 무엇입니까? 호출은 상태 변경과 Ether 전송을 모두 허용하므로 재진입 공격과 같은 공격 벡터를 열어줍니다. 엄격한 입력 검증 및 제어 흐름 관리가 없으면 외부 계약이 콜백 중에 반복적으로 자금을 소모할 수 있습니다.
Delegatecall은 모든 유형의 계약 업그레이드와 호환됩니까? Delegatecall을 사용하면 업그레이드가 가능하지만 신중한 설계가 필요합니다. 스토리지 충돌, 기능 선택기 충돌 및 초기화 문제로 인해 기능이 중단될 수 있습니다. 투명한 프록시와 UUPS 패턴은 이러한 위험을 완화하는 데 도움이 되지만 엄격한 테스트와 감사가 필요합니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 리플, 은행 및 현금: 디지털 재무 혁명과 워싱턴의 새로운 청사진
- 2026-01-31 22:40:02
- 비트코인의 하이 와이어 법안: 레버리지 비율 급증, 변동성 임박
- 2026-01-31 22:20:02
- 스퍼 프로토콜의 SON 토큰: 상장 사가와 어두운 가격 전망
- 2026-01-31 22:15:04
- 기관이 수십억 달러를 끌어내면서 비트코인 가격 하락이 예상됩니다: BTC가 중요한 시점에 직면
- 2026-01-31 22:10:07
- Tria Airdrop의 두 번째 막: 시즌 2 시작, XP 세부 정보 공개
- 2026-01-31 22:05:08
- 은 청산 제기 눈썹: 무슨 일이 일어났고, 그것이 무엇을 의미하는지
- 2026-01-31 22:00:07
관련 지식
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 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을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 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을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
모든 기사 보기














