」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 什麼是語法和語義

什麼是語法和語義

發佈於2024-11-08
瀏覽:614

What are Syntax and Semantics

如果您正在学习一门语言,您可能听说过“语法”这个词并且一直在处理它。 (该死的语法错误)。

几天前的晚上,我在想,我从来没有认真遵循过编程范式和技术,今天我开始从我经常听到的最小主题中学习(即使我已经记住了)。我创建了这个存储库。我采取的学习路径很有特色(在 LEARNING_LIST.md 文件中)。让我们来说说,与我们用来交流思想和感情的自然语言相比,编程语言可以被视为由男性和女性定义的人工语言,最初是为了与计算机进行交流,但同样重要的是,用于在人与人之间交流算法.
例如,语言定义由三个部分组成:

  • 语法:编程语言的语法是定义符号组合的规则集,这些符号组合被认为是该语言中正确结构化的程序。语言的语法定义了它的表面形式。基于文本的编程语言基于字符序列。文本语言的词汇语法指定如何将字符分块为标记。语法是指组合符号以在语言中创建结构良好的句子(或程序)的方式。语法定义了语言成分之间的形式关系,从而提供了构成语言中合法字符串的各种表达式的结构描述。语法仅涉及语言中符号的形式和结构,而不考虑其含义,语法是仅涉及句子本身是否对语言语法有效的概念

  • 语义:语义是关于句子是否具有有效含义。语义揭示了语言中语法上有效的字符串的含义。对于自然语言来说,这意味着将句子和短语与我们经历的对象、想法和感受相关联。对于编程语言,语义描述了计算机在执行该语言的程序时遵循的行为。我们可以通过描述程序的输入和输出之间的关系或通过逐步解释程序如何在真实或抽象机器上执行来公开这种行为。语义学是意义研究的总称。在计算机科学中,编程语言语义的主题旨在为程序赋予精确的数学含义。

低级语义:

在自然语言中,一个句子可能在语法上是正确的,但在语义上却毫无意义。例如句子:

“那个男人从商店买了无限。”

这在语法上是正确的,但在现实世界中没有意义。同样,在编程语言中,语句可能在语法上正确,但在语义上不正确,因为它违反了语言的规则或其预期含义。

在编程的低级语义中,我们关心的是根据语言的类型系统或其他规则,具有正确语法的语句是否也有意义。即使语法可能有效,操作的语义也可能无效。静态类型语言(如 Java)中的类型系统有助于在运行时之前强制执行这些规则,但动态类型语言(如 JavaScript)并不总是在运行时强制执行这些规则。

JavaScript 中的示例:

在松散类型的 JavaScript 中,您可能没有更严格的类型系统带来的保护,并且该语言将允许某些在语义上没有意义的操作。考虑以下 JavaScript 代码:

let name = "Alice";
name = 42;  // No error, but semantically this doesn't make sense.

这里,语法完全有效,并且 JavaScript 允许赋值,但从语义上讲它很奇怪。您尝试将数字 (42) 分配给可能用于保存字符串(名称)的变量。 JavaScript 中没有类型检查来阻止你犯这个错误,但这是一个低级语义错误,因为它与开发人员的意图不一致。
如果我们实施它。它被执行了。没有任何错误!

在更严格的语言中,例如 TypeScript 或 Java,这会在编译期间立即触发类型错误。

打字稿中的示例:

TypeScript 是 JavaScript 的超集,引入了类型检查来防止这些低级语义问题:

let name: string = "Alice";
name = 42;  // Error: Type 'number' is not assignable to type 'string'.

在 TypeScript 中,编译器会检测到语义错误,因为 42 是一个数字,不能分配给声明为字符串的变量。这种类型的强制执行可以保护开发人员免受意外错误的影响。

在 JavaScript 中,为了避免这些低级语义问题,开发人员经常使用运行时检查:

let name = "Alice";

if (typeof name !== "string") {
    throw new Error("Expected a string!");
}

尽管 JavaScript 不强制执行类型,但添加手动检查可以帮助避免错误类型导致程序出现问题。


高级语义:

在更高的层面上,语义关心的是你的程序应该实现什么目标。这不仅仅是关于程序是否具有有效的语法或类型是否正确对齐,而是关于程序是否按照开发人员的预期方式运行,或者解决了它旨在解决的问题。

例如,假设您正在构建一个简单的股票交易系统。代码的高级语义是为了确保系统使用正确的业务逻辑以正确的方式交易股票。即使代码不会产生类型错误或语法错误,它仍然可能无法满足预期的功能。

JavaScript 中的示例:

让我们看一下使用简化的股票交易场景的高级语义的 JavaScript 示例:

let openTrade = {
    symbol: "EURUSD",
    direction: "buy",
    profit: 100
};

function closeTrade(trade) {
    if (trade.profit >= 50) {
        console.log(`Closing trade for ${trade.symbol} with profit of ${trade.profit}`);
    } else {
        console.log(`Trade for ${trade.symbol} is not ready to close.`);
    }
}

// Check if a trade is open for EURUSD and close it if the profit target is reached.
closeTrade(openTrade);

语法正确,程序运行没有错误。然而,想象一下我们现在在更高级别引入了一个错误,例如意外地为同一交易品种输入了两笔交易,这违反了系统的业务规则。

let openTrades = [
    { symbol: "EURUSD", direction: "buy", profit: 100 },
    { symbol: "EURUSD", direction: "sell", profit: 20 }
];

// Check all trades and close any that hit their profit target.
openTrades.forEach(trade => closeTrade(trade));

在这里,两笔交易都是独立处理的,但系统最终会在同一交易品种上进行两笔交易,一笔是买入方向,一笔是卖出方向。这打破了高级业务规则,即在任何给定时间每个交易品种只能有一笔未平仓交易。

虽然代码执行时没有语法或类型错误,但它在高层上是语义不正确。系统逻辑应该确保每个交易品种一次只能有一笔交易处于活动状态。此错误可能会在现实世界的交易系统中导致意想不到的后果,例如财务损失。

要解决此高级语义问题,您需要调整逻辑以确保特定交易品种仅开放一笔交易:

let openTrades = [
    { symbol: "EURUSD", direction: "buy", profit: 100 }
];

function openNewTrade(newTrade) {
    // Ensure no other trades are open for the same symbol.
    const existingTrade = openTrades.find(trade => trade.symbol === newTrade.symbol);
    if (!existingTrade) {
        openTrades.push(newTrade);
        console.log(`Opened new trade for ${newTrade.symbol}`);
    } else {
        console.log(`Cannot open a new trade for ${newTrade.symbol}, trade already exists.`);
    }
}

openNewTrade({ symbol: "EURUSD", direction: "sell", profit: 0 });

此处,逻辑确保如果同一交易品种已存在活跃交易,则无法打开新交易。这是高级语义修复,因为它解决了程序应遵循的核心业务逻辑,而不是语法或类型问题。

  • 语用学:语用学指的是涉及语言使用者的语言方面,即心理和社会学现象,例如效用、应用范围和对使用者的影响。对于编程语言来说,语用包括易于实现、应用效率和编程方法等问题。

这只是每个的基本信息。欲了解更多信息,您可以阅读以下内容:

  • 来源1
  • 来源2 - | 是一个很棒的资源 |
  • 来源 3
  • 来源 4
  • 来源 5
  • 维基百科-语法
  • 维基百科语义
版本聲明 本文轉載於:https://dev.to/m__mdy__m/what-are-syntax-and-semantics-1p3e?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 Golang 中建立 Google Drive 下載器(第 1 部分)
    在 Golang 中建立 Google Drive 下載器(第 1 部分)
    介绍 在本教程中,我们将构建一个功能强大的下载器,允许从Google Drive和其他云提供商下载文件。借助 Golang 高效的并发模式,您将能够同时管理多个下载、流式传输大文件并实时跟踪进度。无论您是下载一些小文件还是处理大型数据集,该项目都将展示如何构建可扩展且强大的下载器,...
    程式設計 發佈於2024-11-08
  • PHP 4 快速部署
    PHP 4 快速部署
    Servbay 已成為高效配置開發環境的領先工具。在本指南中,我們將引導您完成快速、安全地部署 PHP 8.1 的過程,以展示 Servbay 對簡化部署的承諾。 先決條件 確保您的電腦上安裝了 Servbay。您可以從 Servbay 官方網站輕鬆下載。安裝過程人性化;只需按照安...
    程式設計 發佈於2024-11-08
  • 如何繞過驗證碼
    如何繞過驗證碼
    No matter how many times people wrote that the captcha has outlived itself long time ago and no longer works as effectively as its developers would ha...
    程式設計 發佈於2024-11-08
  • 使用 super 呼叫超類別建構函數
    使用 super 呼叫超類別建構函數
    子類別可以使用 super(parameter-list);. 形式來呼叫其超類別定義的建構函數 parameter-list 必須指定超類別建構子所需的參數。 子類別建構子中執行的第一條語句必須始終是 super(); (或 super(parameter-list); 如果需要傳遞參數). ...
    程式設計 發佈於2024-11-08
  • 你能比較 C++ 中不同容器的迭代器嗎?
    你能比較 C++ 中不同容器的迭代器嗎?
    比較來自不同容器的迭代器:一個警示故事在C 中,迭代器提供了一個強大的遍歷集合的機制。然而,在使用來自不同容器的迭代器時,重要的是要意識到這些限制。 比較不同容器的迭代器是否合法的問題經常出現。考慮以下範例:std::vector<int> foo; std::vector<int...
    程式設計 發佈於2024-11-08
  • 幫助 FastAPI:如何為文件翻譯做出貢獻
    幫助 FastAPI:如何為文件翻譯做出貢獻
    One of the great features of FastAPI is its great documentation ?. But wouldn't it be better if more people around the world had access to this docume...
    程式設計 發佈於2024-11-08
  • 如何使用 CSS 和 AngularJS 建立垂直 HTML 表格?
    如何使用 CSS 和 AngularJS 建立垂直 HTML 表格?
    垂直HTML 表格創建具有垂直行的HTML 表格提供了一種獨特的方式來顯示數據,行標題位於左側而不是頂部。要實現此目的,可以套用 CSS 樣式來轉換表格的結構。 CSS 樣式若要將表格行呈現為垂直列,請遵循下列CSS 規則可使用:tr { display: block; float: lef...
    程式設計 發佈於2024-11-08
  • 透過自訂 Hooks 在 React 中重複使用邏輯:實用指南
    透過自訂 Hooks 在 React 中重複使用邏輯:實用指南
    自訂鉤子是React 中的一項強大功能,與React 內建鉤子不同,它用於更具體的目的,並且它是透過將常見功能封裝到獨立函數中來完成的。自訂掛鉤促進可重複使用性、改進元件組織並整體增強程式碼可維護性。 在本指南中,我們將深入探討使用自訂鉤子的目的,以了解創建自訂鉤子的基礎知識以及如何使用其他元件。...
    程式設計 發佈於2024-11-08
  • 使用 ReactJS 建立免費的 AI 圖像生成器
    使用 ReactJS 建立免費的 AI 圖像生成器
    开发者们大家好, 今天,我将向您展示如何使用 ReactJS 创建图像生成器,并且完全可以免费使用,这要感谢黑森林实验室和 Together AI。 第 1 步:设置项目 在本教程中,我们将使用 Vite 来初始化应用程序并使用 Shadcn 来初始化 UI。我假设您已经设置了项目并...
    程式設計 發佈於2024-11-08
  • 字串中的串聯或大括號:哪種方法可以優化效能和美觀?
    字串中的串聯或大括號:哪種方法可以優化效能和美觀?
    字串中的變數連結與大括號:評估效能與美觀在字串操作領域,開發人員經常面臨兩難境地:他們應該連接字串中的變數還是選擇花括號?每種方法都有自己的優點和缺點,我們將深入研究這些優點和缺點,以提供明智的決策。 串聯:傳統方法串聯涉及使用以下方法將變數附加到字串這 '。 '操作員。雖然這種方法...
    程式設計 發佈於2024-11-08
  • 我嘗試過花崗岩。
    我嘗試過花崗岩。
    花岗岩3.0 Granite 3.0 是一个开源、轻量级的生成语言模型系列,专为一系列企业级任务而设计。它原生支持多语言功能、编码、推理和工具使用,使其适合企业环境。 我测试了运行这个模型,看看它可以处理哪些任务。 环境设置 我在Google Colab中设置了Gr...
    程式設計 發佈於2024-11-08
  • 掌握 JavaScript 函數:開發人員綜合指南
    掌握 JavaScript 函數:開發人員綜合指南
    JavaScript Functions A JavaScript function is a block of code designed to perform a particular task. A JavaScript function is executed when "...
    程式設計 發佈於2024-11-08
  • Go 中的機率提前過期
    Go 中的機率提前過期
    关于缓存踩踏 我经常遇到需要缓存这个或那个的情况。通常,这些值会被缓存一段时间。您可能熟悉这种模式。您尝试从缓存中获取一个值,如果成功,则将其返回给调用者并结束。如果该值不存在,您将获取它(很可能从数据库中)或计算它并将其放入缓存中。在大多数情况下,这非常有效。但是,如果您用于缓存...
    程式設計 發佈於2024-11-08
  • Next.js 快取:透過高效的資料獲取來增強您的應用程式
    Next.js 快取:透過高效的資料獲取來增強您的應用程式
    Next.js 中的快取不僅是為了節省時間,還在於減少冗餘網路請求、保持資料新鮮並使您的應用程式像搖滾明星一樣運作。 無論您是想將資料快取更長時間還是按需刷新,Next.js 都能為您提供所需的所有工具。在本文中,我們將詳細介紹如何在 Next.js 中有效地使用快取 Next.js 擴充了 fe...
    程式設計 發佈於2024-11-08
  • 為什麼我的 Go 模板條件檢查失敗?
    為什麼我的 Go 模板條件檢查失敗?
    Go 範本:條件檢查故障排除在 Go 範本渲染中,結構體欄位的條件檢查有時無法如預期運作。考慮以下範例,其中 bool 欄位 isOrientRight 未正確計算:type Category struct { ImageURL string
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3