이상한 질문 일지 모르지만 많은 언어 (Java, C, C ++, Python Haskell에서 논리 연산자로 의미가없는 이유는 무엇입니까? 마지막으로 사용자가 연산자를 추가하여 사소한 것으로 정의했지만)? 논리적 의미는 (특히 주장이나 주장과 같은 표현으로) 작성하는 것이 훨씬 명확하다는 것을 알 수 있습니다.
encrypt(buf, key, mode, iv = null) {
assert (mode != ECB --> iv != null);
assert (mode == ECB || iv != null);
assert (implies(mode != ECB, iv != null)); // User-defined function
}
답변
때로는 의심의 여지가없는 것이 유용 할 수 있습니다. 여러 가지 요점이 그러한 연산자에 반대합니다.
- 문자는
-
와>
분리와 결합 모두 가치가있다. 많은 언어가 이미 다른 것을 의미하기 위해 사용합니다. (많은 사람들이 구문에 유니 코드 문자 집합을 사용할 수 없습니다.) - 프로그래머와 같은 논리적 인 사람들에게도 직관은 매우 직관적입니다. 4 개의 진리표 항목 중 3 개가
true
많은 사람들에게 놀라운 사실입니다. - 다른 모든 논리 연산자는 대칭이므로
->
직교성을 제외합니다. - 연산자를 사용 : 동시에, 쉬운 해결 방법은
!
과||
. - 의미는 논리적
and
/ 보다 훨씬 덜 자주 사용됩니다or
.
이것이 오늘날 운영자가 드문 이유입니다. 새로운 동적 언어가 모든 것에 유니 코드를 사용하고 연산자 오버로드가 다시 유행에 따라 더 일반적이 될 수 있습니다.
답변
답은 수학적 기초 에 있다고 생각합니다 . 일반적으로 의미는 기본이 아닌 부울 대수의 파생 된 연산으로 간주되고 정의됩니다. 프로그래밍 언어는이 규칙을 따릅니다.
이것은 George Boole의 ‘ 사고의 법칙 조사 (1854) ‘제 2 장 발의안 제 1 호입니다 .
추론의 도구로서 언어의 모든 작업은 다음 요소로 구성된 표시 시스템에 의해 수행 될 수 있습니다.
1 일 우리의 개념의 주제로 사물을 나타내는 x, y, & c.와 같은 문자 기호.
2 일. +,-, ×와 같은 작동 신호는 동일한 요소를 포함하는 새로운 개념을 형성하기 위해 사물의 개념이 결합되거나 해결되는 마음의 작동을 나타냅니다.
셋째. 정체성의 표시, =.
그리고 이러한 논리의 상징은 대수학의 과학에서 해당 상징의 법에 부분적으로 동의하고 부분적으로 다른 명확한 법칙에 따라 사용됩니다.
Boole의 부호 +는 오늘날 우리가 부울 ‘or’와 집합의 결합으로 인식하는 것과 동일한 “마음의 조작”을 나타냅니다. 마찬가지로 부호-및 ×는 부울 부정, 집합의 보완, 부울 ‘및’및 집합의 교차에 해당합니다.
답변
업데이트 :이 질문은 2015 년 11 월 내 블로그의 주제였습니다 . 흥미로운 질문에 감사드립니다!
비주얼 베이직 6 (및 VBScript를)을 가지고 Imp
와 Eqv
운영자. 아무도 사용하지 않았습니다. VB.NET에서 둘 다 제거되었습니다. 내 지식으로는 아무도 불평하지 않았다.
Visual Basic 컴파일러 팀 (인턴)에서 일 년 동안 일한 적이 있으며 VB에 이러한 연산자가 있다는 것을 한 번도 눈치 채지 못했습니다. VBScript 컴파일러를 작성하는 사람이 아니 었으므로 구현을 테스트해야했지만 아마도 눈치 채지 못했을 것입니다. 컴파일러 팀 의 담당자 가 기능에 대해 알지 못하고 사용하지 않으면 기능의 인기와 유용성에 대해 알려줍니다.
C와 같은 언어를 언급했습니다. C 또는 C ++ 또는 Java와는 대화 할 수 없지만 C #과는 대화 할 수 있습니다. C #에 대해 사용자가 제안한 기능 목록은 말 그대로 팔보다 길다. 내 지식으로는 C # 팀에 그러한 연산자를 제안한 사람이 없으며 그 목록을 여러 번 살펴 보았습니다.
한 언어로 존재하고 사용되지 않고 다른 언어로 요청되지 않는 기능은 현대 프로그래밍 언어로 만들 가능성이 낮습니다. 특히 예산에 사람들 이 원하는 기능을 만들기에 충분한 시간과 노력과 돈이 없을 때 .
답변
나는 추측 할 수 있지만 그 이유는 매우 간단하고 읽기 쉬운 해결 방법이 있기 때문일 수 있습니다. 당신의 예를 생각해 봅시다 :
if (mode != ECB) assert (iv != null);
assert (mode != ECB --> iv != null); // <-- that's only one character shorter
식이 필요한 경우 대부분의 언어로 제공되는 인라인 if 연산자 (일반적으로 삼항 연산자라고도 함)를 사용할 수 있습니다. 물론 이것은 우아 A --> B
하지는 않지만 사용 사례 수가 다른 연산자를 추가하고 유지하는 것을 정당화하지 못할 수도 있습니다.
assert (mode != ECB ? iv != null : true);
답변
에펠은 의미가있다
실제로 훨씬 더 있습니다. 그것은 엄격한뿐만 아니라 많은 반 엄격한 연산자를 가지고 있습니다.
프로그래머가 그러한 것들을 사용하지 않는 이유는 그들이 무엇인지, 어떻게 사용하는지, 언제 사용하는지, 어떻게 디자인 하는지를 정확히 알도록 훈련받지 않았기 때문입니다. 그들은 결코 훈련을받지 않았기 때문에 컴파일러 작성자에게 요청하지 않기 때문에 컴파일러 사람들은 그러한 메커니즘을 컴파일러에 넣는 것을 귀찮게하지 않습니다. Computer Science 학생들과 Shade-tree 프로그래머가보다 둥근 교육을 받기 시작하면 컴파일러가 따라 잡기 시작합니다.
그런 부울 연산자를 가진 언어가 있고 그 언어를 사용하여 디자인하고 사용하는 방법을 알고 나면 사용하는 것으로 나타났습니다.
Eiffel에서는 계약 어설 션의 부울이 많은 특성으로 인해 계약 별 디자인으로 인해 “implies”키워드를 사용하는 것이 다소 두드러집니다. “묵시적”연산자를 사용하여 적절하고 효율적으로 만 작성할 수있는 일부 계약이 있습니다. 그런 다음 계약이없는 언어는 더 이상 함의 사용을보고, 훈련하고, 구현할 이유가 없다는 의견을 요구합니다.
이것에 덧붙여 대부분의 프로그래머들은 “수학적이고 논리적 인 약점”이라고 이야기의 나머지 부분을 알려줍니다. 당신이 당신의 교육에 수학과 논리가 무겁더라도, 함축과 같은 구문을 구현하지 않는 언어를 선택할 때, 그러한 것들이 불필요하거나 유용하지 않다고 생각하는 경향이 있습니다. 언어에 의문을 제기하는 사람은 거의 없으며 “컴파일러가 필요를 보지 못했음”과 “프로그래머가 필요를 보지 못했음”이라는 끝없는 악순환이됩니다.
대신에, 컴파일러 사람들은 이론으로 백업하고, 씻지 않은 많은 프로그래머들이 생각하거나 요구하는 것에 관계없이 이론에 의해 제안되거나 암시되는 언어 표기법을 작성해야한다 (예 : 객체 지향 이론). 거기에서 교수, 교사 및 기타 전문가들은 “언어 렌즈를 통한 이론”이 아닌 원시 이론을 기반으로 젊은 어리석은 사고를 전문적으로 훈련해야합니다. 이런 일이 발생하면 사람들은 갑자기 깨어나 무엇을 잃어 버렸는지, 무엇을 습격했는지 알게됩니다.
지금 당장-객체 지향과 같은 가장 무도회라는 이론이 많이 있지만, OO-glass-dark-of-[-pick-your-language]입니다. OO에 관한 대부분의 “이론”책은 어떤 언어의 렌즈를 통해 이론이 무엇인지 해석하기를 원하기 때문에 읽을 수 없습니다. 완전히 틀렸다. 수학 기반의 계산기 나 슬라이드 규칙을 가르치는 것과 같습니다. 아니요. 현실은 스스로에 대해 가르친 다음, “과학”이라고 불리는 것을 관찰하기 위해 표기법을 사용합니다. OO-based-on-language-X라는 다른 매쉬는 현실을 거의 나타내지 않도록 왜곡되어 있습니다.
따라서 언어에서 벗어나 원시 이론을 살펴보고 다시 시작하십시오. 언어의 한계, 제약 및 페인트 작업이 이론이 무엇인지 말하지 않도록하십시오. 단순히 이론의 현실이 자신의 표기법을 지시하게 한 다음 거기에서 언어를 공식화하는쪽으로 이동하십시오.
거기에서 함의와 “의미”가 유용 할뿐만 아니라 우아하고 매우 시원 할 수있는 방법을 얻게됩니다.
좋은 일이!
답변
파이썬에는 일종의 숨겨진 방식으로 함축 연산자가 있습니다.
같거나 같지 않은 연산자는 부울 값을 허용하도록 오버로드됩니다. 결과적으로이를 함축 연산자로 사용할 수 있습니다.
예제로 증명 (파이썬 코드) :
print (False <= False) # This will print True.
print (False <= True) # This will print True.
print (True <= False) # This will print False.
print (True <= True) # This will print True.
함축 연산자의 진리표는 다음과 같습니다.
LEFT RIGHT RESULT
F F T
F T T
T F F
T T T
답변
Eiffel에는 “implies”연산자가 있으며 사전 및 사후 조건을 작성하는 데 매우 좋습니다. 불행히도 코드는 C와 같이 언어와 같은 근본적인 강렬함이 아니었고 너무 적은 수의 사람들이 eiffel을 사용 했으므로 연산자로서 “암시”의 아름다움은 잘 알려져 있지 않습니다.