-
bitcoin $103299.489104 USD
-2.75% -
ethereum $3438.818401 USD
-4.09% -
tether $0.999694 USD
-0.02% -
xrp $2.398080 USD
-5.09% -
bnb $962.992856 USD
-3.68% -
solana $154.795444 USD
-7.73% -
usd-coin $0.999881 USD
-0.02% -
tron $0.299080 USD
0.51% -
dogecoin $0.172414 USD
-4.61% -
cardano $0.559226 USD
-5.94% -
hyperliquid $39.224649 USD
-5.04% -
chainlink $15.394534 USD
-6.06% -
bitcoin-cash $506.933641 USD
-2.17% -
stellar $0.282786 USD
-5.75% -
unus-sed-leo $9.205805 USD
-0.38%
Solidity의 뷰 기능과 순수 기능은 무엇이며 가스에 어떤 영향을 미치나요?
View and pure functions in Solidity don’t modify state, enabling free, off-chain execution—ideal for reads and calculations without gas costs.
2025/11/12 18:20
Solidity의 뷰 기능 이해
1. Solidity의 뷰 기능은 블록체인의 상태를 수정하지 않을 것을 약속하는 기능 유형입니다. 계약의 저장 변수에서 읽을 수는 있지만 변경하거나, 이벤트를 내보내거나, 상태를 변경하는 함수를 호출할 수는 없습니다.
- 이러한 기능은 상태를 변경하지 않기 때문에 트랜잭션을 네트워크에 브로드캐스트하지 않고도 Ethereum 노드에서 로컬로 실행될 수 있습니다. 이는 사용자가 외부로 전화할 때 가스 요금을 지불할 필요가 없음을 의미합니다.
- 키워드 뷰는 함수 시그니처에서 명시적으로 선언되어야 합니다. 생략하고 함수가 상태를 수정하려고 시도하면 컴파일러에서 오류가 발생합니다.
- 예를 들어 사용자 잔액 검색, ERC-20 토큰 허용량 확인, 계약에 저장된 구성 매개변수 읽기 등이 있습니다.
- 외부 호출자에게는 무료임에도 불구하고 뷰 함수는 여전히 노드에서 계산 리소스를 소비합니다. 따라서 보기 함수 내부의 지나치게 복잡한 논리로 인해 일부 공급자가 시간 초과 또는 거부를 초래할 수 있습니다.
Solidity의 순수 기능 탐색
1. 순수 함수는 상태 변수를 읽거나 쓰지 않겠다고 약속함으로써 뷰 함수보다 한 단계 더 나아갑니다. 전달된 입력 매개변수에 대해서만 작동합니다.
- 이러한 함수는 일반적으로 저장된 데이터에 의존하지 않는 수학적 계산, 인코딩/디코딩 작업 또는 논리적 검사에 사용됩니다.
- pure 키워드는 컴파일 타임에 이 제한을 적용합니다. 단일 상태 변수에 액세스하려고 시도하면 컴파일이 실패하게 됩니다.
- 뷰 함수와 마찬가지로 순수 함수는 트랜잭션이 필요하지 않기 때문에 외부에서 호출할 때 가스 비용이 발생하지 않습니다. 로컬 노드 리소스를 사용하여 오프체인을 실행합니다.
- 입력 인수를 기반으로 복리를 계산하거나 계약 저장소를 참조하지 않고 암호화 서명을 검증하는 함수를 예로 들 수 있습니다.
수정되지 않는 함수의 가스 영향
1. 스마트 계약 기능이 view 또는 pure 로 표시되면 이에 대한 외부 호출은 트랜잭션을 생성하지 않습니다. 결과적으로 발신자에게 가스가 청구되지 않습니다.
- 그러나 내부적으로 트랜잭션 내의 다른 함수에 의해 뷰나 순수 함수가 호출되는 경우 해당 실행에는 여전히 가스가 소비됩니다. EVM은 상태 변경 발생 여부에 관계없이 모든 작업을 처리해야 합니다.
- 대규모 배열에 대한 반복이나 여러 산술 연산 수행과 같은 함수 내부의 복잡한 계산은 내부적으로 호출될 때 가스 비용을 증가시킵니다.
- 개발자는 특히 상태 변경 트랜잭션 중에 호출될 가능성이 있는 경우 뷰/순수 함수의 계산을 최소화하여 성능을 최적화하는 경우가 많습니다.
- 실제로 상태를 수정할 때 함수에 뷰 또는 순수라는 라벨을 잘못 지정하면 런타임 예외 또는 배포 실패가 발생하여 잠재적으로 개발 시간과 테스트넷 가스가 낭비됩니다.
뷰 및 순수 함수에 대한 일반적인 질문
Q: 뷰 함수가 순수 함수를 호출할 수 있나요? A: 예, 뷰 함수는 순수 함수를 안전하게 호출할 수 있습니다. 순수 함수는 상태를 읽거나 수정하지 않으므로 뷰 함수의 제약 조건과 완벽하게 호환됩니다.
Q: 순수 함수 내에서 상태 변수를 수정하려고 하면 어떻게 되나요? 답변: Solidity 컴파일러는 오류를 생성합니다. 순수 함수는 읽기든 쓰기든 모든 상태 변수에 액세스하는 것이 엄격히 금지됩니다.
Q: web3.js 또는 ethers.js에서 호출할 때 뷰 및 순수 함수가 가스를 사용합니까? A: 아니요. JavaScript 라이브러리를 통해 이러한 함수를 호출하면 트랜잭션이 필요하지 않으므로 가스 비용이 발생하지 않습니다. 실행은 연결된 Ethereum 노드에서 로컬로 발생합니다.
Q: 뷰 함수와 순수 함수 간에 성능 차이가 있나요? A: 가스 비용 및 실행 속도 관점에서 보면 외부에서 호출할 때 본질적인 차이가 없습니다. 둘 다 상태 변경 없이 로컬로 실행됩니다. 내부적으로 성능은 사용된 수정자가 아닌 계산 복잡성에 따라 달라집니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 중국 DEX Sun Wukong: 급증하는 거래량 및 스테이블코인 보유량
- 2025-11-12 20:50:00
- ETF 흐름과 미국 셧다운 드라마 속에서 비트코인 가격이 흔들린다
- 2025-11-12 21:20:01
- AI 피싱, Web3 보안 및 암호화폐 공격: Web3의 서부에서 안전 유지
- 2025-11-12 21:10:01
- 트레이더들이 Meme 코인 및 유틸리티 토큰에 뛰어들다: 플레이가 무엇인가요?
- 2025-11-12 21:30:01
- 비트코인 전송 수수료: $105,000 죄송하고 결제의 미래
- 2025-11-12 20:55:01
- Atom Valley Project의 중요한 날: 그레이터 맨체스터(Greater Manchester)의 새로운 10년 성장
- 2025-11-12 21:00:02
관련 지식
스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?
2025-11-10 05:20:08
스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...
거래 서명에 사용되는 암호화 임시값은 무엇입니까?
2025-11-11 05:59:39
블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...
Solidity 스마트 계약에서 상속은 어떻게 작동하나요?
2025-11-11 22:40:12
Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
Solidity의 라이브러리는 무엇이며 기본 계약과 어떻게 다릅니까?
2025-11-12 09:19:55
Solidity의 라이브러리 이해 1. Solidity의 라이브러리는 상속되지 않고 여러 계약에서 공유할 수 있는 재사용 가능한 기능을 보유하도록 설계된 특별한 유형의 계약입니다. 이러한 함수는 상태 비저장입니다. 즉, 다른 계약의 저장소와 명시적으로 상호 작용하지 않...
Ether를 다른 계약으로 안전하게 보내는 방법은 무엇입니까?
2025-11-09 18:40:05
스마트 계약으로 Ether 보내기: 주요 고려 사항 1. 수신 계약에 지불 가능한 대체 기능 또는 Ether를 수용할 수 있는 지정된 지불 기능이 있는지 확인하십시오. 이것이 없으면 모든 이체가 취소되어 잠재적으로 자금이 영구적으로 잠길 수 있습니다. 2. 외부 계약과...
스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?
2025-11-10 05:20:08
스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...
거래 서명에 사용되는 암호화 임시값은 무엇입니까?
2025-11-11 05:59:39
블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...
Solidity 스마트 계약에서 상속은 어떻게 작동하나요?
2025-11-11 22:40:12
Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
Solidity의 라이브러리는 무엇이며 기본 계약과 어떻게 다릅니까?
2025-11-12 09:19:55
Solidity의 라이브러리 이해 1. Solidity의 라이브러리는 상속되지 않고 여러 계약에서 공유할 수 있는 재사용 가능한 기능을 보유하도록 설계된 특별한 유형의 계약입니다. 이러한 함수는 상태 비저장입니다. 즉, 다른 계약의 저장소와 명시적으로 상호 작용하지 않...
Ether를 다른 계약으로 안전하게 보내는 방법은 무엇입니까?
2025-11-09 18:40:05
스마트 계약으로 Ether 보내기: 주요 고려 사항 1. 수신 계약에 지불 가능한 대체 기능 또는 Ether를 수용할 수 있는 지정된 지불 기능이 있는지 확인하십시오. 이것이 없으면 모든 이체가 취소되어 잠재적으로 자금이 영구적으로 잠길 수 있습니다. 2. 외부 계약과...
모든 기사 보기














