[MIPS] beq 를 안쓰고 bne 를 쓰는 이유는 무엇인가요?
얼마 전에 페이스북에 올라온 질문인데, “MIPS 어셈블리 코드 중 beq 를 안쓰고 bne 를 쓰는 이유는 무엇인가요?” 라는 질문이다. 아래와 같은 C 언어 코드가 있고,if (i == j) f = g + h; else f = g - h;이를 순서도로 나타내면 다음과 같다. 컴파일러와 최적화 옵션에 따라 생성되는 어셈블리 인스트럭션이 아래와 똑같다고 말할 수 없다.일반적으로 컴파일러는 인스트럭션을 생성할 때 조건문의 경우 반대 조건으로 해석해서 인스트럭션을 작성한다. 이런 경우 대부분 인스트럭션의 크기가 짧아지기 때문에 더 적은 클럭에서 명령을 수행할 수 있기 때문이다. 따라서 아래와 같은 어셈블리 코드가 생성된다.# bne 를 사용하는 코드 bne $s3, $s4, Else add $s0, $s..
C++
2015. 5. 12. 04:12
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
- ***** MY SOCIAL *****
- [SOCIAL] 페이스북
- [SOCIAL] 팀 블로그 트위터
- .
- ***** MY OPEN SOURCE *****
- [GITHUB] POWERUMC
- .
- ***** MY PUBLISH *****
- [MSDN] e-Book 백서
- .
- ***** MY TOOLS *****
- [VSX] VSGesture for VS2005,200…
- [VSX] VSGesture for VS2010,201…
- [VSX] Comment Helper for VS200…
- [VSX] VSExplorer for VS2005,20…
- [VSX] VSCmd for VS2005,2008
- .
- ***** MY FAVORITES *****
- MSDN 포럼
- MSDN 라이브러리
- Mono Project
- STEN
- 일본 ATMARKIT
- C++ 빌더 포럼
- .
TAG
- 비주얼 스튜디오
- 땡초
- mono
- umc
- 엄준일
- Windows 8
- ASP.NET
- Team Foundation Server
- Managed Extensibility Framework
- 팀 파운데이션 서버
- 비주얼 스튜디오 2010
- c#
- TFS
- monodevelop
- github
- LINQ
- Visual Studio
- POWERUMC
- Silverlight
- Visual Studio 2008
- TFS 2010
- MEF
- .NET Framework 4.0
- ALM
- Team Foundation Server 2010
- Visual Studio 2010
- Visual Studio 11
- testing
- test
- .NET