Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:102866 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 28487 invoked from network); 16 Jul 2018 18:42:55 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 16 Jul 2018 18:42:55 -0000 Authentication-Results: pb1.pair.com smtp.mail=smalyshev@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=smalyshev@gmail.com; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.192.176 as permitted sender) X-PHP-List-Original-Sender: smalyshev@gmail.com X-Host-Fingerprint: 209.85.192.176 mail-pf0-f176.google.com Received: from [209.85.192.176] ([209.85.192.176:42870] helo=mail-pf0-f176.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id AE/71-39793-E27EC4B5 for ; Mon, 16 Jul 2018 14:42:54 -0400 Received: by mail-pf0-f176.google.com with SMTP id l9-v6so15077141pff.9 for ; Mon, 16 Jul 2018 11:42:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:openpgp:autocrypt:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=dONPRSnbDbUihmL66zOM++KGwcS4PTfh7pWHZ34paIc=; b=Hn+88TvAnO6Q4Ekr+HekzQZxTM1V7IYqYWOoNrUdhZnaYqtrnpziXfJggjxvGrH2Ga uwkyDLxhNMQn2NLZ03vStIxUaxml1FcXGgRsEYDfvA/e8/dc9/AXOcJOKTrJqrssAJ7Z 9ACIGtcsHnsZROGK3qxfTm/I/zcZmqFETgiIgiIqgK840LzgIVE9kmSoqXyxU2CCjwrP HyoT3X7Lqi989omS6pwgCLnZT1Yo/eQw8jE80JoydberlnJFeK7FfeNlxVKby49MUFxv eptkH3nJFJNKlLy8SednWp71LT4m7Uqb81zHyPkdWeGJYqaSyfshnoz7eyFEH03++bUR m47Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:openpgp:autocrypt :message-id:date:user-agent:mime-version:in-reply-to :content-language:content-transfer-encoding; bh=dONPRSnbDbUihmL66zOM++KGwcS4PTfh7pWHZ34paIc=; b=I8GmuhmqPHoGEtr0FYZjcpT7Yzuunzo6/7mAECAjT15ppCLmr6tTJPVPBbH9B8d331 pHOdiX8Q45rzr2/+9Gji57voZNJbEceUSw+NFpk1ommHFliNKh+KNZGRlJJotnPIeeDe 4S+dx9TbCLpqH+EfgdUx+B6x1Du/54jiCij0MX8oSngRqITutlMZLucMralPM0RJB2/7 WoKxpkrk8xTymK9C+Vzk9fgMXiztF1jqMdThf4x8NhkqoT4PmxjP0+AXj0uL7uustetc QjHFdR94IlCgJr/gkGozaG9OKgVK+GqvtBOa2ve8FlEfJpwr65mzAT/ugf+IUb3JhIbQ e56A== X-Gm-Message-State: AOUpUlF4RRdmGUeIlDtcjDib+i+KVqBqZpv6SIMv77irPInsCEJXT0+8 +qPfIazbzuNtdeX4Bl4jpYslgK0= X-Google-Smtp-Source: AAOMgpfh/UbQpRzsRrVPr6Rbg5HE1/ySDFfY65mFxMPuz7667PUGbNE+OaBKyHuHgQHt+Fa3M/BdkA== X-Received: by 2002:a62:700a:: with SMTP id l10-v6mr18843468pfc.71.1531766571612; Mon, 16 Jul 2018 11:42:51 -0700 (PDT) Received: from Stas-Pro-2034.local ([67.23.203.6]) by smtp.gmail.com with ESMTPSA id k190-v6sm29522506pge.28.2018.07.16.11.42.50 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 16 Jul 2018 11:42:50 -0700 (PDT) To: Wes , Rowan Collins Cc: PHP Internals References: <8916EC21-D368-40F8-9ABD-CE0C04A73539@gmail.com> Openpgp: preference=signencrypt Autocrypt: addr=smalyshev@gmail.com; prefer-encrypt=mutual; keydata= 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 Message-ID: <4a18eb8b-1271-4f82-6d5e-4f8350084385@gmail.com> Date: Mon, 16 Jul 2018 11:42:49 -0700 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:60.0) Gecko/20100101 Thunderbird/60.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Subject: Re: [PHP-DEV] Non-nullable properties From: smalyshev@gmail.com (Stanislav Malyshev) Hi! > I agree with you. If someone really wants to have an "uninitialized" field > on purpose, they should do that using the correct type declaration, i.e.: > > ?MyType $myNullable = null; > > When this was started I asked if it was possible to check types right after > object has been constructed, but they said it was inefficient to do so. > If this is still true, then I'm ok with checking on first access instead. I > don't want even more overhead from runtime type checking. > This is definitely not as bad as the "billion dollar mistake" though. The > error still happens, but in a different place. In Java, avoiding these kinds of errors - when the property is not initialized - is almost trivial, and that's not what "billion dollar mistake" is about. Lack of initialization for a final value (which is a frequent case with property values) is detected by the compiler, and most IDEs/analysis tools would alert of lack of initialization for non-final value too. The problem is with usage on null as a substitution for no value/error/unknown value and this value bleeding out into parts of the code that don't know how to handle this situation. -- Stas Malyshev smalyshev@gmail.com